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

Вниз

Подскажите, как ускорить следующую операцию. Копирую изтаблицы   Найти похожие ветки 

 
Георгинчик   (2002-05-02 14:02) [0]

АА в таблицу ZZ все поля при этом меняю тип одного поля со строкового на Real. В таблице порядка 40 000 - 60 000 записей. Обработка выглядит так:

aa.Active := True;
zz.Active := True;
aa.Append;
zz.Append;
aa.Edit;
aa.First;
zz.Insert;
while not aa.Eof do
begin
zz.FieldValues["PHONE"] := aa.FieldValues["PHONE"];
zz.FieldValues["CALL_DATE"] := aa.FieldValues["CALL_DATE"];
...
zz.FieldValues["SUMMA"]:=strtofloat(aa.FieldValues["SUMMA"]);
aa.Next;
zz.Next;
end;
aa.Edit;
zz.Post;

Работает очень долго, можно ли ускорить? Спасибо!


 
DPetrovich ©   (2002-05-02 14:37) [1]

Сделать запрос на выполнение

insert into ZZ
select
... ,
SUMMA=convert(float, SUMMA) -- или аналог для вашей СУБД
, ...
from AA


 
Ura   (2002-05-02 14:40) [2]

1. Попробуй сделать кеширование - если много памяти. И в конце только применить.
2. Не открывай ZZ а напиши хранимую процедуру на вставку в ZZ.
3. Раздели aa на несколько частей и запускай их паралельно - если выдержит сервер лавины запросов.
4. Проверь может в ZZ есть индексы - так вот надо отключить, а потом пересоздать.


 
suds ©   (2002-05-02 19:53) [3]

Согласен с Ura....
А еще, если не юзаешь SQL, можно пользовать insertrecord
Работает быстрее.... проверено



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

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

Наверх




Память: 0.47 MB
Время: 0.013 c
1-88552
zzzzz
2002-05-16 15:07
2002.05.27
Почему размер файла разный?


7-88652
Zool
2002-02-25 10:45
2002.05.27
Drivers


3-88359
Wildhoney
2002-05-01 04:08
2002.05.27
вопрос


3-88320
Hamster
2002-04-30 08:37
2002.05.27
Списание.


14-88613
Satrap
2002-04-17 09:38
2002.05.27
MSDN