Russian Qt Forum
Ноябрь 23, 2024, 11:32
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Qt
>
Базы данных
>
Запись целой таблицы в бд
Страниц: [
1
]
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: Запись целой таблицы в бд (Прочитано 3949 раз)
Danila_Bagrofff
Гость
Запись целой таблицы в бд
«
:
Апрель 03, 2013, 12:57 »
Подскажите, мне нужно передать целую таблицу данных в базу данных.
Можно, конечно, в рамках сессии проинсертить каждую строку во временную #таблицу, а затем отработать
Для большого кол-ва данных было бы проще выполнить один инсерт с кучей данных в бд.
Подскажите.
Записан
carrygun
Гость
Re: Запись целой таблицы в бд
«
Ответ #1 :
Апрель 03, 2013, 13:02 »
Добавить данные с помющью транзакции. Можно составить один INSERT запрос с множеством VALUES. Можно еще посмотреть в сторону QSqlQuery::execBatch(), но в большинстве случаев он разворачивается в тупой цикл из INSERT'ов.
Записан
Bepec
Гость
Re: Запись целой таблицы в бд
«
Ответ #2 :
Апрель 03, 2013, 13:20 »
Не всегда разворачивается. Зависит от базы и драйвера
А так да - используем множественные запросы, если поддерживается базой данный.
Или же используем много запросов в одной транзакции.
Записан
carrygun
Гость
Re: Запись целой таблицы в бд
«
Ответ #3 :
Апрель 03, 2013, 13:49 »
Цитата: Bepec от Апрель 03, 2013, 13:20
Не всегда разворачивается. Зависит от базы и драйвера
А так да - используем множественные запросы, если поддерживается базой данный.
Или же используем много запросов в одной транзакции.
Там буквально один драйвер это умеет из коробки.
Записан
Bepec
Гость
Re: Запись целой таблицы в бд
«
Ответ #4 :
Апрель 03, 2013, 14:12 »
Незнаю точно
Потому и спорить не могу.
Записан
dio
Гость
Re: Запись целой таблицы в бд
«
Ответ #5 :
Апрель 03, 2013, 17:28 »
Еще парочка вариантов:
1. Разбить данные таблицы на пакеты (в виде XML или CSV) и реализовать процедуру массовой загрузки средствами СУБД.
2. Использовать специализированные инструменты загрузки данных (например SQL*Loader для Oracle RDBMS).
Записан
Danila_Bagrofff
Гость
Re: Запись целой таблицы в бд
«
Ответ #6 :
Апрель 04, 2013, 10:20 »
Да, тоже стал смотреть в сторону xml...
Но наложенные платежи по парсингу все-таки великоваты...
Решил делать через временные таблицы в сессии...
Если кто-то натолкнется, то вот полезная статейка, найденная мной по этому поводу:
http://habrahabr.ru/post/96145/
Записан
Страниц: [
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 сферы
=> Говорилка
=> Юмор
=> Объявления
Загружается...