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

Вниз

Ошибка из-за индекса   Найти похожие ветки 

 
Oleg   (2003-06-18 17:39) [0]

посоветуйте, граждане! вот такой код отрабатывается в лет, но стоит лишь включить индекс, происходит зацикливание - в файл выводится постоянно последняя строка...
if SaveDialog1.Execute then begin
AssignFile(FP, SaveDialog1.FileName);
try
Rewrite(FP);
with Table2 do try
//IndexName:="FIO";
DisableControls;
First;

WHILE NOT EOF DO BEGIN
s_nom:=Fields[5].AsString;
L1:="";
L3:="";
L1:=Fields[0].AsString+"*************"+Fields[5].Asstring;
WriteLn(FP, L1);

WHILE Fields[5].AsString=s_nom DO begin
L3:=Table2.Fields[3].AsString+" / "+ Table2.Fields[4].AsString;
WriteLn(FP, L3);
next;
END;

Writeln(FP, "-------------------------");
end;

finally
EnableControls;
end;
CloseFile(FP);
except
on EInOutError do
MessageDlg("Writing error.", mtError, [mbOk], 0);
end;
end;

как же лечить-то


 
Соловьев ©   (2003-06-18 17:43) [1]


> WHILE Fields[5].AsString=s_nom DO begin
> L3:=Table2.Fields[3].AsString+" / "+ Table2.Fields[4].AsString;
> WriteLn(FP, L3);
> next;
> END;

а что это еще такое?


 
Oleg   (2003-06-18 17:47) [2]

это вывод всех записей, относящихся к Fields[5] - фамилия


 
Соловьев ©   (2003-06-18 17:49) [3]

а зачем там цыкл?


 
SaS13   (2003-06-18 18:17) [4]

индекс сортирует данные таким образом что условие Fields[5].AsString=s_nom всегда верно, и происходит зацикливание
сделай проверку
if Eof then Break;


 
Oleg   (2003-06-18 18:20) [5]

ok, thanks!



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

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

Наверх




Память: 0.47 MB
Время: 0.019 c
9-31065
VitGun
2003-01-26 18:25
2003.07.10
Эффекты света в 2D


8-31368
Катерина
2003-03-21 11:50
2003.07.10
Гистограмма


4-31579
Still Swamp
2003-05-08 18:46
2003.07.10
Thread


14-31496
ianus
2003-06-24 17:42
2003.07.10
Tmediaplayer ????? - NO!


1-31355
Anonimus
2003-06-27 15:42
2003.07.10
TBitmap в array of Byte