Russian Qt Forum
Ноябрь 23, 2024, 20:04
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Qt
>
Вопросы новичков
>
QSqlQuery непострочно
Страниц: [
1
]
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: QSqlQuery непострочно (Прочитано 2129 раз)
eXeLe
Гость
QSqlQuery непострочно
«
:
Апрель 17, 2015, 12:06 »
Добрый день!
Встал вопрос по поводу работы с базой.
Обычно раньше работал всегда так:
QString defaultQ;
defaultQ=QString("select pole1,pole2 from my_table");
QSqlQuery query;
query.exec(defaultQ);
while (query.next()) {
MyStringList1.append(query.value(0).toString());
MyStringList2.append(query.value(1).toString());
}
Сейчас столкнулся с проблемой.
Запрос у меня выполняется при старте программы.
Сам запрос возвращает около 3000 строк и программа стартует только после его выполнения.
Соответственно, выполняется она в такой конструкции секунд 10-15, а то и дольше.
Можно ли как-то ответ от SQL Server'а не перебирать построчно и загонять в QStringList, а разово маппить на какой-либо массив строк?
PS: вопрос не в том, что программа долго не запускается. Можно было бы перенести выполнение запроса в другой момент, но это не избавит от долгой обработки выполнения запроса.
Записан
kibsoft
Хакер
Offline
Сообщений: 625
Re: QSqlQuery непострочно
«
Ответ #1 :
Апрель 17, 2015, 15:31 »
Можно попробовать поставить
Код:
void QSqlQuery::setForwardOnly(bool forward)
перед
Код:
query.exec(defaultQ);
Может быстрей будет.
Записан
http://kibsoft.ru
- Download the Qt Media Encoding Library here
The apps that were written using QtMEL:
http://srecorder.com
- Screen recording software
eXeLe
Гость
Re: QSqlQuery непострочно
«
Ответ #2 :
Апрель 17, 2015, 15:41 »
Хм, да, по факту это решило мою проблему. Выполняется практически мгновенно на моем объеме данных.
Спасибо!
Записан
Страниц: [
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 сферы
=> Говорилка
=> Юмор
=> Объявления
Загружается...