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

Вниз

Индекс и длинное строковое поле в FB   Найти похожие ветки 

 
}|{yk ©   (2005-02-22 11:37) [0]

В FB нельзя создать индекс, если длина его составляющих больше 255 байт. Но что мне делать, если больше?
Я попробовал написать триггер
AS
declare variable count_dup integer;
begin
 select count(1) from APP_PLATEG where
 RS_ID=new.rs_id and
 KONTR_ID = new.kontr_id and
 PLAT_NOM = new.plat_nom and
 PLAT_DATE = new.plat_date and
 PLAT_SUM = new.plat_sum and
 DEB_KRED = new.deb_kred and
 KOMENT = new.koment
 into count_dup;
 if (inserting) then
 if (count_dup>1) then
  Exception PLATEG_DUP;
 if (updating) then
  if (new.koment<>old.koment) then
   if (count_dup>0) then
    Exception PLATEG_DUP;
end

вроде, должен работать правильно. Но почему-то дублирование таки есть! Как правильно?


 
Johnmen ©   (2005-02-22 11:46) [1]

>Но что мне делать, если больше?

Достаточно известное решение - вычислять и хранить хеш на данные (длинная строка в данном случае), и делать индекс на хеш (если цель - уникальность).



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

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

Наверх




Память: 0.46 MB
Время: 0.038 c
14-1110455760
mmms
2005-03-10 14:56
2005.03.27
Холодильник молотит без остановки, есть ли спецы?


14-1109786649
_silver
2005-03-02 21:04
2005.03.27
Белгородская сходка.


14-1109753342
NeyroSpace
2005-03-02 11:49
2005.03.27
Нужен эмулятор медленного компьютера для запуска


14-1109919988
PZ
2005-03-04 10:06
2005.03.27
Задача А.Эйнштейна


1-1110638833
[k]NikolaZ
2005-03-12 17:47
2005.03.27
Алгоритмы Архивирования