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

Вниз

Insert 10000 записей как ускорить?   Найти похожие ветки 

 
awp ©   (2004-10-12 16:19) [0]

Необходимо ускорить добавление записей в таблицу.
Есть таблица DBF(по одному адресу) и таблица Oracle(по другому адресу) компонент - ODAC.Net. Обработка примерно 35 сек при запуске exe а при запуске через php 2-3 минуты. Как ускорить? Может поиграть свойствоми ODAC(AutoCommit or CachedUpdate)?

код:

DbfTable.First;
while not DbfTable.Eof do
begin
 for i:= posG to DbfTable.FieldCount - 1 do
 begin
  if Length(Trim(DbfTable.Fields[i].Value)) <> 0 then
  begin
    OraTable.Insert;
    OraTable.FieldByName("k").Value:= DbfTable.FieldValues["k"];
    .....................................
    10 полей
    .....................................
    OraTable.Post;
  end;
 end;
 DbfTable.Next;
end;


 
Johnmen ©   (2004-10-12 16:25) [1]

Надо просто выполнять INSERT INTO ..., а не городить огород с набором данных.


 
roottim ©   (2004-10-12 16:57) [2]

TOraLoader
или Johnmen ©   (12.10.04 16:25) [1]


 
Reindeer Moss Eater ©   (2004-10-12 17:07) [3]

Кардинально ускорить можно так:

1.Создаем скрипт из инсертов или просто текстовый файл в формализованном виде.
2. Жмем его zlib"ом
3. Заливаем на сервер (передавая его процедуре в качестве blob параметра)
4. Находим реализацию zlib на яве и переносим её на сервер.
5. Распаковываем на сервере наш блоб и обрабатываем его там же.


 
awp ©   (2004-10-12 17:21) [4]

Спасибо roottim, попробую OraLoader

Reindeer Moss Eater - так не получится сервер с оракулом на одной машине а загрузка на другой а файл DBF на третей :))))
желание заказчика - закон! :))))


 
Reindeer Moss Eater ©   (2004-10-12 17:24) [5]

А мой способ и не предполагает, что dbf лежит на машине с ораклом.



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

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

Наверх




Память: 0.48 MB
Время: 0.041 c
6-1094536049
WondeRu
2004-09-07 09:47
2004.11.14
Как оследить обрыв сети?


10-1060688888
OlegL
2003-08-12 15:48
2004.11.14
Midas client


1-1098818523
Yanis
2004-10-26 23:22
2004.11.14
С++ => Delphi


3-1098104433
denis24
2004-10-18 17:00
2004.11.14
определение названия тейбла в dbedite связаного с Datasours


3-1097510743
Vsevolod
2004-10-11 20:05
2004.11.14
Сортировка в БД