Russian Qt Forum
Ноябрь 24, 2024, 02:24
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Qt
>
Базы данных
>
Удаление всех записей из таблицы
Страниц: [
1
]
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: Удаление всех записей из таблицы (Прочитано 4322 раз)
Lostinnet
Гость
Удаление всех записей из таблицы
«
:
Сентябрь 24, 2010, 10:15 »
Подскажите как правильно удалять все записи из таблицы БД.
Пробую:
model->removeRows(0, model->rowCount());
model->submitAll();
записи удаляются очень медленно, и размер файла с БД остается прежним, не уменьшается
Записан
BaltikS
Гость
Re: Удаление всех записей из таблицы
«
Ответ #1 :
Сентябрь 24, 2010, 10:23 »
Цитата: Lostinnet от Сентябрь 24, 2010, 10:15
размер файла с БД остается прежним, не уменьшается
Это не значит что записи не удаляются из БД. Они удаляются. Остаётся мусор. Это также зависит от БД.
Записан
Lostinnet
Гость
Re: Удаление всех записей из таблицы
«
Ответ #2 :
Сентябрь 24, 2010, 10:28 »
Вижу что удаляется, но как увеличить скороть и избавится от мусора.
База SQLITE
Записан
crossly
Гость
Re: Удаление всех записей из таблицы
«
Ответ #3 :
Сентябрь 24, 2010, 10:33 »
используй trancate table.... после удаления строк из таблицы размер БД меньше не станет...
.... строки резервируются для последующего использования...
Записан
voronElf
Гость
Re: Удаление всех записей из таблицы
«
Ответ #4 :
Сентябрь 24, 2010, 10:56 »
модель поди по одной строке удаляет, потому и медленно (блокировки-разблокировки таблицы на каждой операции ). Можно конечно все удаление в одну транзакицю общую засунуть (по крайней мере при большом количестве запросов на запись, это дает выигрыш быстродействия очень ощутимый ). но лучше одним запросом DELETE FROM table_name . Запрос TRUNCATE здесь конечно лучше подойдет, только вот вроде SQLITE его не поддерживает.
Записан
Lostinnet
Гость
Re: Удаление всех записей из таблицы
«
Ответ #5 :
Сентябрь 24, 2010, 11:14 »
Спасибо за советы!!!
TRUNCATE действительно почему то не работает ((
но DELETE с транзакцией очень помогло!
и еще один вопросик.
Почему после QSqlDatabase::removeDatabase("Journal"); файл с БД все равно остается недоступным для удаления? Тогда как правильно закрыть БД
Записан
BaltikS
Гость
Re: Удаление всех записей из таблицы
«
Ответ #6 :
Сентябрь 24, 2010, 12:41 »
Цитата: crossly от Сентябрь 24, 2010, 10:33
используй trancate table.... после удаления строк из таблицы размер БД меньше не станет...
.... строки резервируются для последующего использования...
Да зачем? После удаления VACUUM надо дать.....
Записан
BaltikS
Гость
Re: Удаление всех записей из таблицы
«
Ответ #7 :
Сентябрь 24, 2010, 12:45 »
Цитата: Lostinnet от Сентябрь 24, 2010, 11:14
Почему после QSqlDatabase::removeDatabase("Journal"); файл с БД все равно остается недоступным для удаления? Тогда как правильно закрыть БД
ищи по форуму, уже обсуждалось неоднократно...
Записан
Страниц: [
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 сферы
=> Говорилка
=> Юмор
=> Объявления
Загружается...