Михаиллл
МихаилллJune 7, 2020, 8:54 a.m.

Как в QtWebApp правильно подключаться к базе

Добрый день.
Делаю на QtWebApp сервер. Сделал класс DataBase для работы с базой.
Если открывать соединение с базой в классе RequestHandler в конструкторе, то при ображение к базе в функции

void RequestHandler::service(HttpRequest& request, HttpResponse& response)

выдвется ошибка подключения, а если открывать соединение в этой функции, то работает нормально при одном запросе, если идет 2 запрос, пока первый запрос шерстит базу, то выдается ошибка и сервер падает.

07.06.2020 15:36:44.134 1 WARNING  0x20d4 QSqlDatabasePrivate::addDatabase: duplicate connection name 'qt_sql_default_connection', old connection removed.

Скажите пожалуйста как и где создать объект класса DataBase и открыть его, что бы все работало?

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!

8
Evgenii Legotckoi
  • June 7, 2020, 1:13 p.m.

Добрый день.
Я бы сделал подключение к базе данных при старте приложения, а запросы уже отдельно делал.
Но уж точно не в методе RequestHandler::service, ведь судя по его названию, он обрабатывает запросы, а не отвечает за первоначальную инициализацию.

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

    Михаиллл
    • June 7, 2020, 1:56 p.m.

    Если при старте, то получается так, база не конектится и в 1 строке пишет ошибку, при подключениях клиента к серверу выдает ошибки о не подключеной базе.

      Михаиллл
      • June 8, 2020, 5:48 a.m.

      Возможно дело в том, что при подключении к базе каждый раз нужно указывать новое имя подключения. Может быть вы знаете как это сделать? Такой вариант не работает:

          dataBase = QSqlDatabase::addDatabase("QPSQL", "conectionName");
          dataBase.setDatabaseName("db_game_tamada");
          dataBase.setUserName("postgres");
          dataBase.setPassword("1qaz");
          dataBase.setPort(5433);//*/
          if (dataBase.open()) {
              //out<<"db is opened \r\n";
          }
          else {
              //out<<"db not opened \r\n";
          }
      
        Михаиллл
        • June 8, 2020, 2:43 p.m.
        • The answer was marked as a solution.

        Нужно задавать уникально имя подключению базы

            dataBase = QSqlDatabase::addDatabase("QPSQL", "conectionName");
            dataBase.setDatabaseName("db_game_tamada");
            dataBase.setUserName("postgres");
            dataBase.setPassword("1qaz");
            //ResumeDB.setHostName("127.0.0.1");
            dataBase.setPort(5433);//*/
        

        А потом в запросе указывать эту базу

        QSqlQuery query(dataBase);
        

        осталось понять как делать уникальные имена

          Evgenii Legotckoi
          • June 9, 2020, 1:28 a.m.

          добавляйте к имени текущее время.

          QString dataBaseName = QString("db_game_tamada_%1").arg(QDateTime::currentDateTime());
          
            Михаиллл
            • June 9, 2020, 1:37 a.m.

            Я решил добавлять тип запроса + уникальный номер запрашиваюшего устройства + 2 рандомных числа от 0 до 999999, так скорей всего будет уникально, даже если запросы последуют однавременно.

              Evgenii Legotckoi
              • June 9, 2020, 1:53 a.m.
              • (edited)

              А со временем до милисекунд гарантировано будет уникально :-)

                R
                • June 14, 2020, 1:17 p.m.

                Краще всетаки до бази конектитись при старті, не рекомендувавби вам на кожен запит створювати конекшин, так як сервер баз даних може мати лімінт на кількість сесій, і і не рекомендувавби вішати всіх на один конекшин, так як там теж є ліміти, оптимальний варіант для себе, і доречі схожа рекомендація була на стековефло, це декілька конекшинів які видаютсья по черзі на нову сесію (ну це в мому випадку так як в мене клієнт конектиться по websocket)
                час до мілісекунд теж не найкращий варіант бо може бути конфлікт, і я на це декілька разів попадав тому використовую щось типу

                    QSqlDatabase dbServerGlobal;
                    QString m_name_connect = QDateTime::currentDateTime().toString("yyyyMMddhhmmsszzz") + QVariant(QRandomGenerator::global()->generate()).toString();
                    if(!dbServerGlobal.contains(m_name_connect))
                    {
                    // перевіряєм чи вже є з такою назвою
                    }
                

                видаляти доречі можна по

                QSqlDatabase::removeDatabase(name_connect);
                

                при запуску програми є функція типу

                static QStringList listConnection;
                
                void dataBaseConnect::loadConnectionList()
                {
                    int number_connection = 10;
                    listConnection.clear();
                    for(int i = 0; i < number_connection; i++)
                    {
                        QString name_conn = QString("con_%1").arg(i);
                
                
                        listConnection.append(name_conn);
                
                    }
                }
                

                а потім при конекті клієнта по черзі по кругу видаєтсья їм назва

                QString dataBaseConnect::getUserConnection()
                {
                    if((listConnection.size() - 1) == indexLastConnection)
                    {
                        indexLastConnection = 0;
                    }
                
                    QString ret = listConnection.at(indexLastConnection);
                
                    indexLastConnection++;
                    return ret;
                
                }
                

                ну f корbстувач вже використовує при запиті

                QSqlQuery m_query(QSqlDatabase::database(m_user->nameConnectDb()));
                

                доречі в цьому впадку потрібно переконатись що сервер не закриваю конекти по таймауту

                  Comments

                  Only authorized users can post comments.
                  Please, Log in or Sign up
                  e
                  • ehot
                  • March 31, 2024, 2:29 p.m.

                  C++ - Тест 003. Условия и циклы

                  • Result:78points,
                  • Rating points2
                  B

                  C++ - Test 002. Constants

                  • Result:16points,
                  • Rating points-10
                  B

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

                  • Result:46points,
                  • Rating points-6
                  Last comments
                  k
                  kmssrFeb. 8, 2024, 6:43 p.m.
                  Qt Linux - Lesson 001. Autorun Qt application under Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
                  Qt WinAPI - Lesson 007. Working with ICMP Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
                  EVA
                  EVADec. 25, 2023, 10:30 a.m.
                  Boost - static linking in CMake project under Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
                  J
                  JonnyJoDec. 25, 2023, 8:38 a.m.
                  Boost - static linking in CMake project under Windows Сделал всё по-как у вас, но выдаёт ошибку [build] LINK : fatal error LNK1104: не удается открыть файл "libboost_locale-vc142-mt-gd-x64-1_74.lib" Хоть убей, не могу понять в чём дел…
                  G
                  GvozdikDec. 18, 2023, 9:01 p.m.
                  Qt/C++ - Lesson 056. Connecting the Boost library in Qt for MinGW and MSVC compilers Для решения твой проблемы добавь в файл .pro строчку "LIBS += -lws2_32" она решит проблему , лично мне помогло.
                  Now discuss on the forum
                  a
                  a_vlasovApril 14, 2024, 6:41 a.m.
                  Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Евгений, добрый день! Такой вопрос. Верно ли следующее утверждение: Любое Android-приложение, написанное на Java/Kotlin чисто теоретически (пусть и с большими трудностями) можно написать и на C+…
                  Павел Дорофеев
                  Павел ДорофеевApril 14, 2024, 2:35 a.m.
                  QTableWidget с 2 заголовками Вот тут есть кастомный QTableView с многорядностью проект поддерживается, обращайтесь
                  f
                  fastrexApril 4, 2024, 4:47 a.m.
                  Вернуть старое поведение QComboBox, не менять индекс при resetModel Добрый день! У нас много проектов в которых используется QComboBox, в версии 5.5.1, когда модель испускает сигнал resetModel, currentIndex не менялся. В версии 5.15 при resetModel происходит try…
                  AC
                  Alexandru CodreanuJan. 19, 2024, 11:57 a.m.
                  QML Обнулить значения SpinBox Доброго времени суток, не могу разобраться с обнулением значение SpinBox находящего в делегате. import QtQuickimport QtQuick.ControlsWindow { width: 640 height: 480 visible: tr…

                  Follow us in social networks