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

Вниз

Загрузка данных в Oracle   Найти похожие ветки 

 
id_privin   (2002-06-20 19:55) [0]

Профи, помогите!

Ситуация : загружаю данные в Oracle, для этого в Query пишу insert .... и в Variables кладу массивы данных.

Проблема : когда массивы короткие (до 1000 записей) все отлично,
а когда больше (2000 и более) то программа начинает жрать память ( >100M) и дико тормозить( 1000 записей - ~2с, а 6000 - больше минуты).

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


 
Yuvich ©   (2002-06-21 14:11) [1]

Я думаю, это присходит от того, что запись всех данных происходит в одной транзакции, поэтому для большого количества записей Оракле тратит много времени на запись в rollback сегмент.

Единственный путь - делать транзакции короче: одна запись (группа записей, связанных между собой логически) - одна транзакция или пакет записей ( >100, <1000) - одна транзакция.

Другой путь - сделать загрузку данных вне транзакции: перевести сервер (сессию) в режим not logged и загрузить данные, при этом кол-во записей не имеет значения. Но это, скорее всего, надо делать на сервере и из файла, например Лоадером.



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

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

Наверх




Память: 0.46 MB
Время: 0.021 c
1-47284
Gamar
2002-06-29 17:40
2002.07.15
Изменение цвета столбца в Run-Time


14-47697
Забыл
2002-06-17 19:06
2002.07.15
Есть тут кул хацкеры?


1-47505
goliaph
2002-07-04 12:37
2002.07.15
Мастера, помогите!!!! Горю. Ыспользование таймера.


1-47541
sector
2002-06-27 22:23
2002.07.15
помогите ответом


14-47753
Дмитрий Баранов
2002-06-13 13:07
2002.07.15
Знатокам Perl