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

Вниз

TTable.FindKey находит то, что не находит Locate   Найти похожие ветки 

 
clickmaker ©   (2003-08-21 15:42) [0]

Причем для TFloatField. Т.е., если создать индекс на такое поле, потом выполнить FindKey(Value) - запись найдена. А если индекс не создавать и сказать Locate("FieldName", Value, []) - ни фига не найдено. В чем грабли?


 
Reindeer Moss Eater ©   (2003-08-21 15:44) [1]

В фактических значениях параметров функций.


 
clickmaker ©   (2003-08-21 15:48) [2]

Так они одни и те же. Вот такой код пашет

Table_kadr.AddIndex("I_TAB_N", "TAB_N", []);
Table_kadr.indexname:="I_TAB_N";

if Table_kadr.findkey([table1TAB_N.value]) then
// все Ок


А такой нет

if Table_kadr.Locate("TAB_N", table1TAB_N.AsFloat, []) then
// пусто


Вместо AsFloat ставил Value - та же история


 
clickmaker ©   (2003-08-21 15:58) [3]

Причем, с индексом и Locate начинает находить. Ничё не понимаю... Разве Locate не для того, чтобы искать поля просто по имени, без индексов? Или это чисто DBaseвские заморочки?


 
Desdechado ©   (2003-08-21 16:40) [4]

locate использует индексы, если они есть


 
Johnmen ©   (2003-08-21 16:45) [5]

Все дело в погрешности разрядной сетки.



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

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

Наверх




Память: 0.47 MB
Время: 0.014 c
3-33436
Sergant
2003-08-19 17:24
2003.09.11
Проблема с упаковкой БД при использовании Halcyon 6.95


7-33825
Vladislav
2003-06-27 13:33
2003.09.11
Какие права у текущего пользователя?


14-33809
МАКСИК
2003-08-22 08:20
2003.09.11
Вопрос именно по API


1-33536
dez
2003-09-01 19:03
2003.09.11
CoInitialize has not been called


14-33740
Zheks
2003-08-25 00:32
2003.09.11
Shape