Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2005.06.29;
Скачать: CL | DM;

Вниз

Как побыстрее удалить большую часть записей из таблицы ?   Найти похожие ветки 

 
ANB ©   (2005-05-17 10:50) [0]

В таблице было 17 миллионов записей. Дамп из-за этого 3.5Г. Поднимается долго. И места на винте маловато. А нужен он только для тестов. Решил оставить не больше миллиона записей. Попробавал удалить одним delete - через час кончился роллбэк сегмент. Поставил на удаление в цикле по 1000 записей с коммитом. Вот так :

declare
i number;
-- 17139893
begin
i := 0;
while (i <= 17000000) loop
 delete from PC_EX_JOURNAL tbl where rownum <= 1000;
 Commit;
 i := i + 1000;
end loop;
end;

Вчера с 15.00 до 10.30 удалилось только 6 миллионов. Пока скрипт работает - мой комп жутко тормозит. Мне уже надоело сидеть в форуме Потрепаться, работать надо. Как бы это ускорить ?


 
ANB ©   (2005-05-17 10:51) [1]

Поставил отметку Oracle - почему то не села.


 
ANB ©   (2005-05-17 10:51) [2]

Поставил отметку Oracle - почему то не села.


 
Sergey13 ©   (2005-05-17 10:55) [3]

Может стОит попробовать переписать нужные записи во временную таблу, затранкейтить исходную и перелить из временной (или переименовать ее если констрейнтов немного)?


 
Reindeer Moss Eater ©   (2005-05-17 10:56) [4]

В твоем случае правильнее делать так:
Создавать промежуточную таблицу с помощью create table as select .....
Затем транкейт основной таблице.
А затем вставка в нее того, что в промежуточной.


 
Reindeer Moss Eater ©   (2005-05-17 11:02) [5]

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


 
ANB ©   (2005-05-17 11:07) [6]

Круто. 15 секунд и все готово. Спасибо.



Страницы: 1 вся ветка

Текущий архив: 2005.06.29;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.047 c
6-1112101349
Макс Т.
2005-03-29 17:02
2005.06.29
Автозаполнение и Twebbrowser


14-1117429492
Тульский
2005-05-30 09:04
2005.06.29
Игра на гитаре


14-1117215030
Dream3D
2005-05-27 21:30
2005.06.29
Посоветуйте сайт


1-1117793543
zaw
2005-06-03 14:12
2005.06.29
ОКРУГЛЕНИЕ


8-1109790766
seregka
2005-03-02 22:12
2005.06.29
Прозрачность изображения+наложение 2-х изображений