Главная страница
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.071 c
1-1110349102
kblc
2005-03-09 09:18
2005.03.27
TRichEdit &amp; *.doc


3-1109080112
denis24
2005-02-22 16:48
2005.03.27
Проблема с Fibplus 5.3.0


1-1110828527
Гость
2005-03-14 22:28
2005.03.27
Подскажите, как вставить данные из формы в Word?


1-1110894372
Dysan
2005-03-15 16:46
2005.03.27
компиляция проекта но без vcl


9-1104316737
Trimp
2004-12-29 13:38
2005.03.27
Как задать SmoothNormal?