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

Вниз

Удаление записей после фильтрации...   Найти похожие ветки 

 
BillyJeans ©   (2003-09-04 12:03) [0]

Существует ли метод удаления отфильтрованных записей в таблице? Желательно одной командой...


 
Sandman25 ©   (2003-09-04 12:07) [1]

Оставшиеся после фильтра записи можно удалить командой
with Query do
begin
sql.add("delete from table where " + Dataset.filter);
execproc;
end;

Если использовался OnFilterRecord, то можно пройтись по всем записям (First, while not Eof do ... Next) удалить их (Dataset.Delete).


 
BillyJeans ©   (2003-09-04 12:15) [2]

У меня TTable, а (First, while not Eof do ... Next) вовсе не одна команда, и выполняется медленно :(


 
BillyJeans ©   (2003-09-04 12:19) [3]

да, причем Next в данном случае все испортит!


 
Sandman25 ©   (2003-09-04 12:19) [4]

Ну и что, что Table? Добавьте еще TQuery, можете его динамически создать, если он редко используется.

with TQuery.Create(nil) do
try
DatabaseName := Table.DatabaseName;
Sql.Add("Delete from " + Table.TableName + " where " + Table.Filter);
ExecProc;
finally
Free;
end;


 
BillyJeans ©   (2003-09-04 12:28) [5]

ExecProc тоже не выход, т.к. будет медленно отрабатывать из-за разных фильтров...


 
Sandman25 ©   (2003-09-04 12:33) [6]

[5] BillyJeans © (04.09.03 12:28)

Что значит из-за разных фильтров? Или удаляются все сразу (с помощью TQuery, и тогда абсолютно не важно, существует ли вообще какой-то там TTable) или по одной (с помощью цикла по TTable). Других способов нет.


 
BillyJeans ©   (2003-09-04 12:40) [7]

еще варианты есть?


 
VAleksey ©   (2003-09-04 12:42) [8]

Next не нужен!!
While not Table1.Eof do Table1.Delete;
Вообще - это одна команда :-). С точки зрения паскаля ес-с-но.


 
Sandman25 ©   (2003-09-04 12:48) [9]

[8] VAleksey © (04.09.03 12:42)

>Next не нужен!!

Точно. Позор на мои седины :)

>Вообще - это одна команда :-). С точки зрения паскаля ес-с-но.

Application.Run - тоже одна команда, с точки зрения синтаксиса.
И главный begin end - тоже :)



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

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

Наверх




Память: 0.48 MB
Время: 0.027 c
7-82523
Borgir
2003-07-11 14:30
2003.09.25
Температура CPU


6-82352
Кодер
2003-07-27 21:46
2003.09.25
Потоки, потоки и еще раз потоки


1-82215
XopoSHiy
2003-09-11 19:41
2003.09.25
Формочки... Много формочек!!!


3-82062
Alik$
2003-08-13 06:32
2003.09.25
Визуальный просмотр и вставка


4-82540
vic_774N
2003-07-24 00:02
2003.09.25
EnumResourceTypes, EnumResTypeProc ...