Главная страница
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-1253685178
TUser
2009-09-23 09:52
2009.12.06
Еще про письма Президенту и ответы на них


15-1250841620
Empleado
2009-08-21 12:00
2009.12.06
На чем мультики делать?


4-1223891391
Игорь
2008-10-13 13:49
2009.12.06
NtQuerySystemInformation


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


15-1255119652
Kolan
2009-10-10 00:20
2009.12.06
А кто-нибудь пробовал писать визуализаторы?