Главная страница
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.01 c
1-88536
Коля
2002-05-16 08:51
2002.05.27
Мастера, помогите сложить 2 даты


1-88401
V/S
2002-05-16 21:46
2002.05.27
В разделе Статьи есть текст программы «Монитор каталогов».


1-88520
Andrew_A
2002-05-15 22:06
2002.05.27
не могу разобраться, помогите...


1-88562
Martyn
2002-05-16 14:29
2002.05.27
QReport - сообщение


1-88557
Сатир
2002-05-16 15:12
2002.05.27
Определение битмапы для нового компонента