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

Вниз

Query переполняет память.   Найти похожие ветки 

 
DimS75   (2002-08-29 16:43) [0]

Уважаемые мастера может это где-то и было...
конструкция вот такого вида неоправданно потребляет память.
сомнительно, что в данном случае free таки ее освобождает
или есть какой либо другой способ
заставить TQuery освободить память?

query1:=TQuery.Create(nil);
Query1.sql.clear;
Query1.sql.add("insert into a (b) values(1)");
Query1.execsql;
Query1.sql.clear;
Query1.sql.add("select id from a where b=1");
query1.open;
myid[i]:=query1.fieldbyname("id");
query1.close;
query1.free;
при цикле порядка 50000 возникает ошибка притом совершенно не в программе - потребляемая память растет до 30Мб и выпадает отладчик с совершенно левым адресом


 
oss   (2002-08-29 16:46) [1]

не квери переполняет а myid[i]


 
Turalyon ©   (2002-08-29 16:47) [2]

А может быть было бы дешевле не создавать TQuery динамически 50000 раз (и не удалять соответственно), а пользоваться одним статическим?


 
maxi ©   (2002-08-29 16:57) [3]

Не знаю, не знаю ...
У меня такая проблема была с компонентом DOA.
Я поступал так : использовал не Close ,а CloseAll.
Первый курсор не очищает и копит, второй - всё делает правильно.
Не знаю, есть ли в Query1 такая фича ... т.е. CloseAll.
Смотри, пробуй ...


 
fool ©   (2002-08-29 19:42) [4]

потребляемая память растет не из-за free, а из-за того, что
Query1.sql.add("select id from a where b=1");
query1.open;
с каждой итерацией возвращает все бОльший объем выборки


 
deleon ©   (2002-08-30 09:37) [5]

Это вина не TQuery, а BDE...



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

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

Наверх




Память: 0.47 MB
Время: 0.011 c
3-60938
Sergey V. Shadrin
2002-08-28 07:32
2002.09.19
консольное приложение


14-61281
Palladin
2002-08-23 15:52
2002.09.19
интересно, кто нибуть пишет не классы (class) а объекты (object)


14-61261
Turalyon
2002-08-20 08:37
2002.09.19
Антивирус


1-61102
иван61
2002-09-08 21:35
2002.09.19
Как открыть проводник диска А из своей программы в модальном окне


14-61270
MIFI
2002-08-23 14:12
2002.09.19
нужно узнать путь до страницы каторая запустила