Теперь Кью работает в режиме чтения

Мы сохранили весь контент, но добавить что-то новое уже нельзя

Как устроена передача данных (информации) от введённых данных на интерфейсе пользователя до сохранения в базе данных?

ПрограммированиеБазы данных
Анонимный вопрос
  ·   · 2,2 K
Я - программист, который знает немного о циклах и...  · 6 нояб 2021
I. Клиент-серверная архитектура приложения
  1. Пользователь вводит данные через элементы управления и ввода в графическом интерфейсе
  2. Клиентская программа отсылает эти данные по сети (как правило через протокол прикладного уровня HTTP с транспортным уровнем TCP/IP) на сервер приложения. В качестве форматов данных для отправки на сервер приложения выступают такие форматы сериализации как JSON, XML и ряд бинарных (но это сейчас очень редко).
  3. Сервер приложения парсит эти данные, валидирует, анализирует и на основе этого отправляет запрос по сети на сервер базы данных (на сервера БД, если база распределенная). Это как правило делается по протоколу транспортного уровня TCP с кастомными протоколами прикладного уровня (у MySQL свой протокол, у PosgreSQL свой). Также он модет отправлять на каждый запрос от клиента множество запросов объединенных или не объединенных одной транзакцией. Как правило данные на сервер БД отправляются в бинарном виде.
  4. Сервер базы данных получает от сервера приложения команды на исполнение запросов (это может быть, например, текст SQL команды и следующие за ней бинарные данные аргументов или номер server side prepared statement и далее бинарные данные аргументов), исполняет запросы и отправляет серверу приложения ответ в виде результатов запросов или коды ошибок. Во время исполнения запросов при успешном выполнении их данные на носителе могут изменяться. Происходит это так: сервер БД вызывает функции операционной системы для работы с накопителем, передавая им адреса и значения, которые нужно поменять или добавить или удалить. Эти функции вызывают соответствующие функции драйверов этих накопителей, которые обеспечивают передачу этих данных по интерфейсу связи с этими устройствами хранения. Микропроцессор устройства хранения, получив эти данные, выполняет инструкции, которые приводят к модификации данных на носителе.
  5. Если сервер БД расположен на одном и том же хосте с сервером приложения, то для связи между ними может использоваться общая память (shared memory), именованные каналы (named pipes) и прочие механизмы межпроцессного взаимодействия (interprocess communication)
II. Десктопное приложение
Отличий особенно нет за исключением того, что нет слоя сервера приложения: клиентская программа и сервер приложения совмещены в одном, передача данных происходит в оперативной памяти.
Отличий особенно нет за исключением того, что нет слоя сервера приложения:
где ты этот бред узнал?
программист надомник  · 3 нояб 2021
insert into mytable (a1,a2,a3,a4 и так далее предварительно есть поля ввода, куда пользователь что-то ввел, ну или нет и перед тем как выполнить запрос на добавление надо через интерфейс доступа базы данных совместить... Читать далее