DF
Dis FictionMarch 8, 2022, 6:21 p.m.

Общий вопрос по клиент-серверному приложению с MYSQL

c++, сети

Всем доброго дня, в учебных целях пишу на С++ клиент-серверное приложение, с использованием MYSQL.
На данном этапе есть решение с 2 проектами клиента и сервера, работает обмен сообщениями между ними.
Вопрос - правильно ли я понимаю что делать дальше, нужно в проекте сервера создать взаимодействие с локальной БД, а со стороны клиента "сообщениями" отправлять SQL-запросы на сервер? Или всё делается как-то иначе?

We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.

Do you like it? Share on social networks!

7
Виктор Калесников
  • March 8, 2022, 8:01 p.m.
  • (edited)

Отправлять от клиента сообщения с SQL запросами? Как то странно или я не понял.
А так то нужен протокол для обмена данными между сервером и клиентом.

1) К примеру модифицированный SRT
struct Packet {
bool mode; // тип пакета: управляющий = 1 . данные = 0
uint16_t controlType; // команда
uint16_t subType;
uint32_t typeInfo;
uint32_t timeStamp;
uint32_t destSocket;
QByteArray data; // сообщение
};
В QByteArray data пакуй любой тип данных (QDataStream) и на сервере распаковывай. А на основе полученных данных делай SQL запрос.

2) А можно в json паковать. Еще правильней хоть и менее производительней.

p.s Пример бинарного протокола выше это актуально для высокопроизводительных UDP серверов.
Хотя для highload QByteArray через QDataStream медленно работает. Там нужно извращаться с memcpy и тд.

    Я делаю без Qt в этот раз, на чистых плюсах с использованием сокетов. На данном этапе я пока что могу запустить проекты клиента и сервера, в консоли писать сообщение к примеру от клиента, и оно отобразится на сервере, т.е. обычный чат в консоли. Сообщения в формате char[].
    Я хотел бы понять, как устроено клиент-серверное приложение с базой данных, это мой первый такой проект, так что заранее извиняюсь за возможно глупые вопросы. Просто не хочу сделать непойми что.
    Как я это себе представляю - от клиента приходит сообщение с запросом серверу, в проекте сервера происходит подключение к локальной базе данных:

    if (!mysql_real_connect(conn, "localhost", "root", "mypassw11", "mytest_DB2", NULL, NULL, 0)) 
    

    далее некий запрос:

    if (mysql_query(conn, "SELECT * FROM university") > 0)
    

    И далее результат запроса возвращается клиенту.
    В правильном ли направлении я вообще двигаюсь? И вообще правильно ли связывать клиент-серверное приложение и базу данных таким образом, или всё должно выглядеть вообще иначе, а вот так никто не делает?

      Виктор Калесников
      • March 9, 2022, 12:11 a.m.
      • (edited)

      Упаковывай запрос клиента в json и распаковывай на сервере.
      Для упаковки найди библиотеку сериализации в json.

      Хотя конечно можно string/char (sql команда) с запросом от клиента отправлять на сервер.
      Это самое простое и само собой напрашивающееся. Хотя это как то бестолково на мой взгляд.

      Тебе в любом случае нужен протокол обмена данных между сервером и клиентом.
      И соответственные обработчики на обоих сторонах. Ищи варианты как использовать json.

        Смог подключить json к visual studio, но send() принимает только поток байтов, по умолчанию для передачи запроса через send() использовалось const char*, для передачи объекта действительно нужно использовать сериализацию.
        Правильно ли я понимаю, что суть всех этих манипуляций в том, что-бы передавать серверу четко структурированный запрос из ключей и значений, дальше сервер из значений сам составляет запрос к БД, и поэтому Вы сказали, что передавать запрос просто строкой бестолково?

          Дв, именно так.
          Если бы все обошлось только запросами в базе то в теории можно было бы и запрос sql строку посылать.
          Но так не делают по причине того что наверняка появится нужда каких либо действий на стороне сервера\клиента не связанных с базой. И тогда строка уже не SQL запрос содержит а команду на исполнение. А как сервер определит что эту строку нужно не как запрос в базу посылать а отдельно обработать?

            Спасибо за помощь, вроде всё +- получилось. Пока выглядит так - с помощью сериализации перевожу json в строку и передаю серверу, там обратно собираю в json, пока в учебных целях у json-объекта 2 поля - тип команды (команда серверу/запрос к БД), и сама команда. Далее получаю из БД результирующую таблицу, и возвращаю клиенту построчно. Это похоже на правду?

              Виктор Калесников
              • March 11, 2022, 3:19 p.m.

              Да, в целом правильно.

                Comments

                Only authorized users can post comments.
                Please, Log in or Sign up
                Г

                C++ - Test 001. The first program and data types

                • Result:66points,
                • Rating points-1
                t

                C++ - Test 001. The first program and data types

                • Result:33points,
                • Rating points-10
                t

                Qt - Test 001. Signals and slots

                • Result:52points,
                • Rating points-4
                Last comments
                G
                GoattRockSept. 3, 2024, 8:50 p.m.
                How to Copy Files in Linux Задумывались когда-нибудь о том, как мы привыкли доверять свои вещи службам грузоперевозок? Сейчас такие услуги стали неотъемлемой частью нашей жизни, особенно когда речь идет о переездах между …
                ВР
                Влад РусоковAug. 2, 2024, 8:47 a.m.
                How to Copy Files in Linux Screenshot_20240802-065123.png
                d
                dblas5July 5, 2024, 6:02 p.m.
                QML - Lesson 016. SQLite database and the working with it in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                k
                kmssrFeb. 9, 2024, 2:43 a.m.
                Qt Linux - Lesson 001. Autorun Qt application under Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
                Qt WinAPI - Lesson 007. Working with ICMP Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
                Now discuss on the forum
                Evgenii Legotckoi
                Evgenii LegotckoiJune 24, 2024, 10:11 p.m.
                добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
                F
                FynjyJuly 22, 2024, 11:15 a.m.
                при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …
                BlinCT
                BlinCTJune 25, 2024, 8 a.m.
                Нарисовать кривую в qml Всем привет. Имеется Лист листов с тосками, точки получаны интерполяцией Лагранжа. Вопрос, как этими точками нарисовать кривую? ChartView отпадает сразу, в qt6.7 появился новый элемент…
                BlinCT
                BlinCTMay 5, 2024, 12:46 p.m.
                Написать свой GraphsView Всем привет. В Qt есть давольно старый обьект дял работы с графиками ChartsView и есть в 6.7 новый но очень сырой и со слабым функционалом GraphsView. По этой причине я хочу написать х…
                Evgenii Legotckoi
                Evgenii LegotckoiMay 2, 2024, 9:07 p.m.
                Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Добрый день. По моему мнению - да, но то, что будет касаться вызовов к функционалу Андроида, может создать огромные трудности.

                Follow us in social networks