Главная страница
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.042 c
6-1106623413
OneFragLeft
2005-01-25 06:23
2005.03.27
Broadcast передача файлов по Lan


4-1108224480
TeNY
2005-02-12 19:08
2005.03.27
как правильно использовать функцию EnumResourceNames.


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


3-1109362678
ali_tash
2005-02-25 23:17
2005.03.27
как войти в базу FireBird если не знаеш пароля ?


14-1110053626
Vasya.ru
2005-03-05 23:13
2005.03.27
Помогите найти алгоритм