Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2003.07.10;
Скачать: [xml.tar.bz2];

Вниз

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

 
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;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.45 MB
Время: 0.009 c
1-31175
Серёга
2003-06-27 17:28
2003.07.10
Нужно ли


1-31179
Тимур
2003-06-27 17:56
2003.07.10
Перевод формулы


3-31133
Rustik
2003-06-18 11:39
2003.07.10
Подскажите как сформировать массив типа дата начиная с дата1


1-31232
seal
2003-06-28 17:57
2003.07.10
RichEdit


14-31406
Nucl
2003-06-25 15:34
2003.07.10
Компонент для прокрутки Flash





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский