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

Вниз

Поиск в бд   Найти похожие ветки 

 
Л.Д.   (2009-10-20 13:15) [0]

Нужно проверить существует ли определенное значение поля в таблице БД. Использую FindKey, но указатель записи при True перемещается на эту запись, как сделать без перемещения указателя.


 
Л.Д.   (2009-10-20 13:25) [1]

Сделал так, но не нравиться с точки зрения оптимальность:


function TDM.SectionExists(SectionId: Integer): Boolean;
var
 OldItemId: Integer;
begin
 OldItemId := Ffield_item_id.AsInteger;
 Result := (SectionId = const_HomeSectionId)
   or (cmp_TableByKey_.FindKey([SectionId]) and (Ffield_group_id.AsInteger = 0)
   and (Ffield_flags.AsLargeInt <> 1));
 cmp_TableByKey_.FindKey([OldItemId]);
end;


 
Сергей М. ©   (2009-10-20 13:26) [2]

Никак.


 
clickmaker ©   (2009-10-20 13:26) [3]

> как сделать без перемещения указателя

SQL
if exists (select ... )


 
Сергей М. ©   (2009-10-20 13:28) [4]


> не нравиться с точки зрения оптимальность


Правильно не нравится.

Делай закладку, после этого ищи ключ и в случае нахождения возвращайся на сохраненную закладку, после чего уничтожай ее.


 
Сергей М. ©   (2009-10-20 13:29) [5]

Или, если это TClientDataSet, делай клон НД и ищи ключ в клоне - курсоры оригинального и клонированного НД независимы.



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

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

Наверх




Память: 0.47 MB
Время: 0.013 c
11-1208498240
Дмитрий Пырин
2008-04-18 09:57
2009.12.06
Работа с потоками


15-1254861007
Юрий
2009-10-07 00:30
2009.12.06
С днем рождения ! 7 октября 2009 среда


15-1255128109
Kerk
2009-10-10 02:41
2009.12.06
Анна Потсар учит как правильно графоманить в интернете


15-1255088311
g11
2009-10-09 15:38
2009.12.06
Сведения в exe-файлах


2-1256063307
Novii
2009-10-20 22:28
2009.12.06
Bitmap and Bitmap