Михаиллл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
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!
B
- Bogdannn
- March 27, 2024, 7:15 p.m.
C++ - Test 001. The first program and data types
- Result:46points,
- Rating points-6
Last comments
Qt Linux - Lesson 001. Autorun Qt application under Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
АК
Qt WinAPI - Lesson 007. Working with ICMP Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
Анатолий КононенкоFeb. 5, 2024, 1:50 a.m.
EVADec. 25, 2023, 10:30 a.m.
Boost - static linking in CMake project under Windows Сделал всё по-как у вас, но выдаёт ошибку [build] LINK : fatal error LNK1104: не удается открыть файл "libboost_locale-vc142-mt-gd-x64-1_74.lib" Хоть убей, не могу понять в чём дел…
Qt/C++ - Lesson 056. Connecting the Boost library in Qt for MinGW and MSVC compilers Для решения твой проблемы добавь в файл .pro строчку "LIBS += -lws2_32" она решит проблему , лично мне помогло.
Now discuss on the forum
Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Евгений, добрый день! Такой вопрос. Верно ли следующее утверждение: Любое Android-приложение, написанное на Java/Kotlin чисто теоретически (пусть и с большими трудностями) можно написать и на C+…
Павел ДорофеевApril 14, 2024, 2:35 a.m.
Вернуть старое поведение QComboBox, не менять индекс при resetModel Добрый день! У нас много проектов в которых используется QComboBox, в версии 5.5.1, когда модель испускает сигнал resetModel, currentIndex не менялся. В версии 5.15 при resetModel происходит try…
Как получить в массив значения из связанной модели? Спасибо, разобрался:))
AC
QML Обнулить значения SpinBox Доброго времени суток, не могу разобраться с обнулением значение SpinBox находящего в делегате. import QtQuickimport QtQuick.ControlsWindow { width: 640 height: 480 visible: tr…
Alexandru CodreanuJan. 19, 2024, 11:57 a.m.
Добрый день.
Я бы сделал подключение к базе данных при старте приложения, а запросы уже отдельно делал.
Но уж точно не в методе RequestHandler::service, ведь судя по его названию, он обрабатывает запросы, а не отвечает за первоначальную инициализацию.
В общем подключайтесь к базе данных при первоначальной инициализации, а уж потом различные запросы выполняйте.
Если при старте, то получается так, база не конектится и в 1 строке пишет ошибку, при подключениях клиента к серверу выдает ошибки о не подключеной базе.
Возможно дело в том, что при подключении к базе каждый раз нужно указывать новое имя подключения. Может быть вы знаете как это сделать? Такой вариант не работает:
Нужно задавать уникально имя подключению базы
А потом в запросе указывать эту базу
осталось понять как делать уникальные имена
добавляйте к имени текущее время.
Я решил добавлять тип запроса + уникальный номер запрашиваюшего устройства + 2 рандомных числа от 0 до 999999, так скорей всего будет уникально, даже если запросы последуют однавременно.
А со временем до милисекунд гарантировано будет уникально :-)
Краще всетаки до бази конектитись при старті, не рекомендувавби вам на кожен запит створювати конекшин, так як сервер баз даних може мати лімінт на кількість сесій, і і не рекомендувавби вішати всіх на один конекшин, так як там теж є ліміти, оптимальний варіант для себе, і доречі схожа рекомендація була на стековефло, це декілька конекшинів які видаютсья по черзі на нову сесію (ну це в мому випадку так як в мене клієнт конектиться по websocket)
час до мілісекунд теж не найкращий варіант бо може бути конфлікт, і я на це декілька разів попадав тому використовую щось типу
видаляти доречі можна по
при запуску програми є функція типу
а потім при конекті клієнта по черзі по кругу видаєтсья їм назва
ну f корbстувач вже використовує при запиті
доречі в цьому впадку потрібно переконатись що сервер не закриваю конекти по таймауту