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

Вниз

Рекурсивная функция   Найти похожие ветки 

 
Вованчик ©   (2004-02-24 15:52) [0]

Здравствуйте.

Написал рекурсивную функцию:

function GetSQL(var N: String): String;
var Query: TIBQuery;
Str: String;
begin
Query := TIBQuery.Create(Self);
Query.DataBaseName := Data.DB;
Query.Transaction := Data.Transaction;
Query.SQL.Text := ‘SELECT N FROM Vid_Calculation_Table’ + fos_Number_Otdel +
‘WHERE N_Vid = ’ + N;
Query.Open;
Result := ‘’;
While not Query.eof do
begin
Str := Query.FieldByName(‘N’).asString;
Result := Result + ‘ OR N_Vid = ’ + Str + GetSQL(Str);
Query.Next;
end;
Query.Close;
Query.Free;
end;

но она выдает эксепшин "не могу выполнить на закрытом датасете" на строке Query.Next, убираю
Query.Close;
Query.Free;
все работает без проблем, но тогда экземпляров может создаться очень много...

В чем может быть проблема? По идее то должен закрыться соответсвующий экземляр Query и функция продолжить работу, но все почему то не так ... Помогите разобраться ...

Спасибо.


 
jack128 ©   (2004-02-24 16:02) [1]

не может быть..Ты же открыл куери. Это точно реальный код?? может ты случайно в рабочем коде Query.Close в цикл поставил??


 
Вованчик ©   (2004-02-24 16:06) [2]

может может, самый реальный код :(
> может ты случайно в рабочем коде Query.Close в цикл поставил??
если б так :)



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

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

Наверх




Память: 0.47 MB
Время: 0.015 c
1-12363
Layner
2004-02-25 11:20
2004.03.05
Подскажите плз, как сгенерировать GUID (globally unique identifi)


6-12467
Hogo
2003-12-29 08:14
2004.03.05
VoIP в TurboPower Async Professional


1-12322
Lena19
2004-02-22 21:35
2004.03.05
как убить объект (самого себя)


1-12377
lika
2004-02-25 08:09
2004.03.05
Разбор лога


6-12466
zig
2003-12-29 10:35
2004.03.05
Особеннсть метода Socket.SendText