KL
Konstantin LazarevАқп. 9, 2017, 4:26 Т.Қ.

Работа с базами данных

QSqlDataBase

Подскажите пожалуйста, когда нужно закрывать базу данных. После отправки одного запроса или по окончанию работы всего приложения?

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!

14
Evgenii Legotckoi
  • Ақп. 10, 2017, 1:30 Т.Ж.

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

А при завершении программы соединение само должно отключаться корректно.

Дергать подключение к базе данных при каждом запросе тоже не очень хорошо. Лишняя нагрузка будет.

    KL
    • Ақп. 10, 2017, 2:46 Т.Ж.

    Я перенес свою базу данных на сайт beget.com Там наблюдается та же проблема. Первые 3-5 минут работает хорошо. После чего нужен коннект. Написал им в службу поддержки. Жду ответ.

      Evgenii Legotckoi
      • Ақп. 10, 2017, 3:26 Т.Ж.

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

        KL
        • Ақп. 10, 2017, 4:34 Т.Ж.

        Здравствуйте. В целях безопасности, на MySQL серверах установлено ограничение на время ожидания. При подключении к серверу MySQL можно увеличить время ожидания командой: set session wait_timeout=600; Обратите внимание, что подключение к базе данных не должно быть постоянно открытым, а должно устанавливаться только при обмене данными. Письмо от администрации сервера.

          Evgenii Legotckoi
          • Ақп. 10, 2017, 4:59 Т.Ж.

          Ну что могу сказать. Так-то логично.

          Обмен данными может быть в течение 10-15 секунд. А потом может быть длительный простой, просто не на каждый же чих открывать и закрывать соединение. Как вариант, можно проверять периодически с помощью запроса SELECT 1 из какой-нибудь таблицы, есть ли подключение. Если выполняется с ошибкой, то переоткрывать соединение.

          Либо просто при неудачном рабочем запросе пытаться переподключить соединение.

            KL
            • Ақп. 10, 2017, 5:02 Т.Ж.

            set session wait_timeout=600; этот параметр я не могу изменить при помощи программы QT?

              KL
              • Ақп. 10, 2017, 5:12 Т.Ж.

              Если время коннекта нельзя увеличить, мне нужно делать запросы через открытие закрытие. Наверное так и будет.

                Evgenii Legotckoi
                • Ақп. 10, 2017, 5:49 Т.Ж.

                Да в общем-то можно. Это же SQL запрос тоже. Попробуйте через QSqlQuery.

                QSqlQuery query;
                query.prepare("SET SESSION wait_timeout = 600;");
                query.exec();
                

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

                  KL
                  • Ақп. 10, 2017, 6:05 Т.Ж.

                  Я понял. Спасибо Вам, перейду к реализации выше изложенного.

                    KL
                    • Ақп. 10, 2017, 6:12 Т.Ж.

                    Последний вопрос)

                    QSqlQuery query;
                    query.prepare("SET SESSION wait_timeout = 600;");
                    query.exec();
                    
                    Необходимо отправлять перед каждым обращением или можно время задать (час например) вначале соединения и больше не прописывать его?
                      Evgenii Legotckoi
                      • Ақп. 10, 2017, 6:26 Т.Ж.

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

                      Так что, если Вы пользуетесь бесплатным виртуальным хостингом, то скорее всего покрутить конфигурационный файл не удастся. Да и судя по ответу, что Вы привели выше - это так и есть.

                        KL
                        • Ақп. 10, 2017, 6:44 Т.Ж.

                        Проблема решена. Базы данных работают адекватно. Я увеличил время сессии на час. Для меня этого вполне достаточно.

                          KL
                          • Ақп. 17, 2017, 4:09 Т.Ж.
                          • Жауап шешім ретінде белгіленді.
                          #include "db.h"
                          #include <QSqlQuery>
                          #include <QDebug>
                          #include <QSqlQuery>
                          void db::Connect()
                          {
                          
                              if(QSqlDatabase::contains(QSqlDatabase::defaultConnection))
                              {
                                DB=QSqlDatabase::database();
                              }
                              else
                              {
                              DB=QSqlDatabase::addDatabase("QMYSQL");
                              DB.setPassword("*********");
                              DB.setHostName("*********.beget.tech");
                              DB.setDatabaseName("*********_comment");
                              DB.setUserName("*********_comment");
                              if (!DB.open())
                              {qDebug() << "Failed to connect to root mysql admin";}
                              else
                              {
                                  qDebug()<<"cool";
                              }
                              QSqlQuery query;
                              query.prepare("SET SESSION wait_timeout = 36000;");
                              query.exec();
                              }
                          }
                          
                          db::db()
                          {
                          
                          }
                          
                          QStringList db::SaytPage()
                          {
                              Connect();
                              QStringList List;
                              QString str;
                              List.clear();
                              QSqlQuery query(DB);
                             query.exec("SELECT namepage FROM page");
                              while(query.next())
                              {
                                 str=query.value(0).toString();
                                 List.push_back(str);
                              }
                              DB.close();
                              DB.removeDatabase("*********_comment");
                              return List;
                          }
                          
                            KL
                            • Ақп. 17, 2017, 4:14 Т.Ж.

                            Приложение работает без предупреждений. Отредактируйте пожалуйста пароли)

                              Пікірлер

                              Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
                              Кіріңіз немесе Тіркеліңіз
                              Г

                              C++ - Тест 001. Первая программа и типы данных

                              • Нәтиже:66ұпай,
                              • Бағалау ұпайлары-1
                              t

                              C++ - Тест 001. Первая программа и типы данных

                              • Нәтиже:33ұпай,
                              • Бағалау ұпайлары-10
                              t

                              Qt - Тест 001. Сигналы и слоты

                              • Нәтиже:52ұпай,
                              • Бағалау ұпайлары-4
                              Соңғы пікірлер
                              G
                              GoattRockҚыр. 3, 2024, 1:50 Т.Қ.
                              Linux жүйесінде файлдарды қалай көшіруге болады Задумывались когда-нибудь о том, как мы привыкли доверять свои вещи службам грузоперевозок? Сейчас такие услуги стали неотъемлемой частью нашей жизни, особенно когда речь идет о переездах между …
                              d
                              dblas5Шілде 5, 2024, 11:02 Т.Ж.
                              QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                              k
                              kmssrАқп. 8, 2024, 6:43 Т.Қ.
                              Qt Linux - Сабақ 001. Linux астында Autorun Qt қолданбасы как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
                              АК
                              Анатолий КононенкоАқп. 5, 2024, 1:50 Т.Ж.
                              Qt WinAPI - Сабақ 007. Qt ішінде ICMP Ping арқылы жұмыс істеу Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
                              Енді форумда талқылаңыз
                              Evgenii Legotckoi
                              Evgenii LegotckoiМаусым 24, 2024, 3:11 Т.Қ.
                              добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
                              F
                              FynjyШілде 22, 2024, 4:15 Т.Ж.
                              при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …
                              BlinCT
                              BlinCTМаусым 25, 2024, 1 Т.Ж.
                              Нарисовать кривую в qml Всем привет. Имеется Лист листов с тосками, точки получаны интерполяцией Лагранжа. Вопрос, как этими точками нарисовать кривую? ChartView отпадает сразу, в qt6.7 появился новый элемент…
                              BlinCT
                              BlinCTМамыр 5, 2024, 5:46 Т.Ж.
                              Написать свой GraphsView Всем привет. В Qt есть давольно старый обьект дял работы с графиками ChartsView и есть в 6.7 новый но очень сырой и со слабым функционалом GraphsView. По этой причине я хочу написать х…
                              Evgenii Legotckoi
                              Evgenii LegotckoiМамыр 2, 2024, 2:07 Т.Қ.
                              Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Добрый день. По моему мнению - да, но то, что будет касаться вызовов к функционалу Андроида, может создать огромные трудности.

                              Бізді әлеуметтік желілерде бақылаңыз