Главная страница
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.022 c
1-47247
Валет
2002-06-28 14:42
2002.07.15
Bmp


3-47138
GAlexis
2002-06-24 12:03
2002.07.15
TDBGrid и TDataSource


6-47639
Sergey_001
2002-05-03 14:52
2002.07.15
У меня к вам два вопроса.


14-47773
Erlan
2002-06-13 09:33
2002.07.15
Беда просто.


3-47124
Ramil
2002-06-21 21:09
2002.07.15
У кого получался сетевой IB под win95/98