© EVILEG 2015-2018
Рекомендует хостинг
TIMEWEB
9 января 2018 г. 13:34

Запрос к базе в отдельном потоке.

поток, запрос, модель

В связи с тем что запросы к базе выполняется достаточно долго (удаленные базы на объектах с низкой скоростью интернет соединения) запросы хочется выполнять в отдельных потоках.

Вопрос в следующем: Возможно ли получать из потока модель(QSqlQueryModel, QAbstractItemModel или какую либо другую).
Если нет, то каким образом лучше всего передавать результат работы запроса в основной поток для дальней шей обработки.
Данные нужны только для чтения.
  • #
  • 9 января 2018 г. 21:28

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

В таком случае логичнее, чтобы у баз данных было некое API , через которое можно было бы получать интересующие данные в том же JSON формате через QNetworkAccessManager . Или это не представляется возможным?

Баз много. но рабочей подключение одно (корректировка информации)

Просто для создания скрипта корректировки нужно получить данные из 5-10 таблиц.
Хотелось бы получить массив данных в отдельном потоке, затем передать его в главный и потом работать с ним.
Вопрос в том в каком виде передать инфу из потока.

Я бы тогда передал вектор некоторой информации, классов, которые будут отвечать за строки в таблице.


class TableInfo
{
public:
    /* Секция геттеров и сеттеров */
  
private:
    int m_id;
    int m_info_1;
    int m_info_2;
    QString m_description;  
}
В самом потоке информацию можно получить через QSqlQuery. Потом пройтись в цикле и подготовить вектор этих элементов
QVector<TableInfo> infoVector;
Сам вектор можно передавать через сигнал слотовое соединение, как сделано вот в этой статье про moveToThread . Думаю, что Вы её уже видели.

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

Спасибо за "пинок" в нужном направлении. :-)

Пожалуйста ))

Ответы

Только авторизованные пользователи могут отвечать на форуме.
Пожалуйста, Авторизуйтесь или Зарегистрируйтесь
15 июня 2018 г. 12:42
Nicky

C++ - Тест 004. Указатели, Массивы и Циклы

  • Результат 100 баллов
  • Очки рейтинга 10
15 июня 2018 г. 12:36
Nicky

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

  • Результат 57 баллов
  • Очки рейтинга -2
15 июня 2018 г. 12:29
Nicky

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

  • Результат 46 баллов
  • Очки рейтинга -6
Последние комментарии
18 июня 2018 г. 7:12
EVILEG

PyQt5 - Урок 007. Работаем с QML QtQuick (Сигналы и слоты)

Я вот сейчас банальность скажу, но у меня всё работало. Так что даже и не знаю, надо на код смотреть, что ещё у вас добавлено или отсутствует из библиотек. P/S/ Извините, вы сейчас вс...
18 июня 2018 г. 7:10
EVILEG

Qt/C++ - Урок 042. PopUp уведомление в стиле Gnome с помощью Qt

Недоработки, вряд ли этот зверь вообще является официально поддерживаемым
18 июня 2018 г. 7:01
EVILEG

QML - Урок 016. База данных SQLite и работа с ней в QML Qt

что-то мне сдаётся, что здесь просто пересобрать проект нужно с удалением build каталога
18 июня 2018 г. 7:00
EVILEG

Qt - WinAPI. Как показать запущенное приложение поверх своего приложения

Если зарыться в API системы, то, думаю, что можно, тут тоже использовался WinAPI.
16 июня 2018 г. 15:19
pro100belik

Qt - WinAPI. Как показать запущенное приложение поверх своего приложения

А можно по ID процесса  выводить на передний план окно? myProcess->processId();
Сейчас обсуждают на форуме
19 июня 2018 г. 7:56
EVILEG

как редактировать порядок обхода этементов по нажатию TAB в Qt5 qml

Что-то наподобие такого TextField { Keys.onReturnPressed: nextItemInFocusChain().forceActiveFocus()}
19 июня 2018 г. 6:31
kabanov

Как сохранить фокус в TextField после перезагрузки модели

Rectangle { ListView { id: listView delegate: Item { id: cDelegate Item { Row { ComboBox { ...
18 июня 2018 г. 10:51
alex_lip

Qml and JavaScript

В том то и дело что просто в JS так нельзя Если использовать state - onReleased - не нужен вот так все работает Text { ...
18 июня 2018 г. 7:16
EVILEG

почему не выполняется код после вызова слота?

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

Рекомендуемые страницы