Russian Qt Forum
Июля 04, 2025, 13:28
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Qt
>
Базы данных
>
Sql и Thread
Страниц: [
1
]
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: Sql и Thread (Прочитано 5060 раз)
nikolay
Гость
Sql и Thread
«
:
Июля 18, 2016, 12:49 »
Есть приложение, задача которого вывод из базы данных кучи данных. Есть идея запихнуть выполнения запросов в отдельный thread. Теперь вопрос, как с ним работать? Отправлять запросы на запрос, но как результат получать?
Пример:
Запрос к БД №1;
Запрос к БД №2;
Запрос к БД №3.
Затем повалятся ответы, причём в хаотичном порядке...
Ответ из БД №2
Ответ из БД №3
Ответ из БД №1
Как ответы идентифицировать? Что это именно ответ от 1 или 2 или 3-го запроса. И вообще правильно работать с БД в отдельном потоке? Может по другому построить архитектуру?
Заранее спасибо за ответы!
Записан
Old
Джедай : наставник для всех
Offline
Сообщений: 4350
Re: Sql и Thread
«
Ответ #1 :
Июля 18, 2016, 12:57 »
Цитата: nikolay от Июля 18, 2016, 12:49
Как ответы идентифицировать? Что это именно ответ от 1 или 2 или 3-го запроса. И вообще правильно работать с БД в отдельном потоке? Может по другому построить архитектуру?
Для каждого потока создавайте свое подключение к БД.
Ничего путаться не будет.
Записан
nikolay
Гость
Re: Sql и Thread
«
Ответ #2 :
Июля 18, 2016, 13:08 »
А правильно ли это, что от одного пользователя будет, например, 10 подключений (от 10 запросов соответственно)? И ещё, на мой взгляд, каждый раз устанавливать новое соединение с БД, на это будет уходить время.
«
Последнее редактирование: Июля 18, 2016, 13:13 от nikolay
»
Записан
Old
Джедай : наставник для всех
Offline
Сообщений: 4350
Re: Sql и Thread
«
Ответ #3 :
Июля 18, 2016, 13:30 »
Цитата: nikolay от Июля 18, 2016, 13:08
А правильно ли это, что от одного пользователя будет, например, 10 подключений (от 10 запросов соответственно)?
А почему нет?
Цитата: nikolay от Июля 18, 2016, 13:08
И ещё, на мой взгляд, каждый раз устанавливать новое соединение с БД, на это будет уходить время.
Конечно, нужно один раз их создать вместе с потоками.
Записан
rudireg
Гость
Re: Sql и Thread
«
Ответ #4 :
Октября 31, 2016, 19:08 »
А если поток один и он пуляет запросы в другой поток, который работает с БД
Тогда как идентифицировать?
Хотя если пуляется в 3 разных БД
то следует сделать для каждого БД отдельное подключение
«
Последнее редактирование: Октября 31, 2016, 19:10 от rudireg
»
Записан
Страниц: [
1
]
Вверх
Печать
« предыдущая тема
следующая тема »
Перейти в:
Пожалуйста, выберите назначение:
-----------------------------
Qt
-----------------------------
=> Вопросы новичков
=> Уроки и статьи
=> Установка, сборка, отладка, тестирование
=> Общие вопросы
=> Пользовательский интерфейс (GUI)
=> Qt Quick
=> Model-View (MV)
=> Базы данных
=> Работа с сетью
=> Многопоточное программирование, процессы
=> Мультимедиа
=> 2D и 3D графика
=> OpenGL
=> Печать
=> Интернационализация, локализация
=> QSS
=> XML
=> Qt Script, QtWebKit
=> ActiveX
=> Qt Embedded
=> Дополнительные компоненты
=> Кладовая готовых решений
=> Вклад сообщества в Qt
=> Qt-инструментарий
-----------------------------
Программирование
-----------------------------
=> Общий
=> С/C++
=> Python
=> Алгоритмы
=> Базы данных
=> Разработка игр
-----------------------------
Компиляторы и платформы
-----------------------------
=> Linux
=> Windows
=> Mac OS X
=> Компиляторы
===> Visual C++
-----------------------------
Разное
-----------------------------
=> Новости
===> Новости Qt сообщества
===> Новости IT сферы
=> Говорилка
=> Юмор
=> Объявления
Загружается...