Главная страница
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.011 c
15-1254495687
Cyrax
2009-10-02 19:01
2009.12.06
Кто-нибудь знает, что такае "партномер" ?


13-1124001775
oslep
2005-08-14 10:42
2009.12.06
Множественный оператор SELECT для DataAdapter


15-1255033807
Юрий
2009-10-09 00:30
2009.12.06
С днем рождения ! 9 октября 2009 пятница


15-1254762749
Константинов
2009-10-05 21:12
2009.12.06
Ксера паспорта при регистрации домена


2-1256018021
Джон Сильвер
2009-10-20 09:53
2009.12.06
Назначение прав доступа NTFS для групп