Главная страница
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.026 c
14-82406
Delphi5.01
2003-09-04 21:48
2003.09.25
Angliski internacionalni iazik?


3-82147
АлеКс
2003-09-03 04:13
2003.09.25
Не срабатывают события TADOQuery


14-82400
Dmitriy O.
2003-09-03 08:53
2003.09.25
Я счастлив что я есть


14-82447
Soft
2003-09-07 13:58
2003.09.25
Что такое ЗЛО?


3-82156
freeman2003
2003-09-03 16:38
2003.09.25
Не выполняется хранимая процедура на SQL server из delphi