Главная страница
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.01 c
15-1255033807
Юрий
2009-10-09 00:30
2009.12.06
С днем рождения ! 9 октября 2009 пятница


9-1183815378
Dib@zol
2007-07-07 17:36
2009.12.06
По часовой стрелке


2-1255610309
XTasy
2009-10-15 16:38
2009.12.06
Глобальные переменные delphi


4-1222413068
Riply
2008-09-26 11:11
2009.12.06
RtlCopyUnicodeString и IRQL


11-1208498240
Дмитрий Пырин
2008-04-18 09:57
2009.12.06
Работа с потоками