Михаиллл07 червня 2020 р. 08:54
Как в 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 и открыть его, что бы все работало?
Рекомендуємо хостинг TIMEWEB
Стабільний хостинг, на якому розміщується соціальна мережа EVILEG. Для проектів на Django радимо VDS хостинг.Вам це подобається? Поділіться в соціальних мережах!
AD
- Akiv Doros
- 11 листопада 2024 р. 14:58
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:50бали,
- Рейтинг балів-4
m
- molni99
- 26 жовтня 2024 р. 01:37
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:80бали,
- Рейтинг балів4
m
- molni99
- 26 жовтня 2024 р. 01:29
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:20бали,
- Рейтинг балів-10
Останні коментарі
ИМ
Django - Підручник 017. Налаштуйте сторінку входу до Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
Игорь Максимов22 листопада 2024 р. 11:51
Evgenii Legotckoi31 жовтня 2024 р. 14:37
Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
Игорь Максимов05 жовтня 2024 р. 07:51
QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Тепер обговоріть на форумі
Evgenii Legotckoi24 червня 2024 р. 15:11
t
google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
tonypeachey115 листопада 2024 р. 06:04
NSProject04 червня 2022 р. 03:49
IscanderChe31 жовтня 2024 р. 15:43
Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
Добрый день.
Я бы сделал подключение к базе данных при старте приложения, а запросы уже отдельно делал.
Но уж точно не в методе RequestHandler::service, ведь судя по его названию, он обрабатывает запросы, а не отвечает за первоначальную инициализацию.
В общем подключайтесь к базе данных при первоначальной инициализации, а уж потом различные запросы выполняйте.
Если при старте, то получается так, база не конектится и в 1 строке пишет ошибку, при подключениях клиента к серверу выдает ошибки о не подключеной базе.
Возможно дело в том, что при подключении к базе каждый раз нужно указывать новое имя подключения. Может быть вы знаете как это сделать? Такой вариант не работает:
Нужно задавать уникально имя подключению базы
А потом в запросе указывать эту базу
осталось понять как делать уникальные имена
добавляйте к имени текущее время.
Я решил добавлять тип запроса + уникальный номер запрашиваюшего устройства + 2 рандомных числа от 0 до 999999, так скорей всего будет уникально, даже если запросы последуют однавременно.
А со временем до милисекунд гарантировано будет уникально :-)
Краще всетаки до бази конектитись при старті, не рекомендувавби вам на кожен запит створювати конекшин, так як сервер баз даних може мати лімінт на кількість сесій, і і не рекомендувавби вішати всіх на один конекшин, так як там теж є ліміти, оптимальний варіант для себе, і доречі схожа рекомендація була на стековефло, це декілька конекшинів які видаютсья по черзі на нову сесію (ну це в мому випадку так як в мене клієнт конектиться по websocket)
час до мілісекунд теж не найкращий варіант бо може бути конфлікт, і я на це декілька разів попадав тому використовую щось типу
видаляти доречі можна по
при запуску програми є функція типу
а потім при конекті клієнта по черзі по кругу видаєтсья їм назва
ну f корbстувач вже використовує при запиті
доречі в цьому впадку потрібно переконатись що сервер не закриваю конекти по таймауту