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

Вниз

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

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

Наверх




Память: 0.46 MB
Время: 0.011 c
3-82073
Centurion
2003-09-05 14:29
2003.09.25
Ошибка БД


8-82343
KoNDoR
2003-05-29 21:22
2003.09.25
Триангулированая поверхность


1-82189
pendalf
2003-09-07 13:50
2003.09.25
Как узнать, какое сейчас число и сколько времени?


14-82426
sashas
2003-09-08 12:31
2003.09.25
Ужас!!!


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





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский