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

Вниз

Умный триггер в InterBase   Найти похожие ветки 

 
RomanH ©   (2006-04-07 15:30) [0]

Здраствуйте мастера. Существует 2 таблицы Men и TMen
MenID  MFam |       TMenID  TMFam TMAction
00001  AAAA  |       10001    BBBBB        1

Пишу такой триггер чтобы добавить запись в таблицу Men необходимо сначало проверить TMenID, если он меньше 10 000,
то New.MenID=Gen_ID(Gen_Men,1):

create trigger bef_ins_men for men
active before insert
as
declare variable men_ID integer;
declare variable Men_action integer;
begin
select TMenID,TMAction from MenT  where TMenID<10000 into :men_ID,Men_action;
if (:men_id<10000) then new.menid=gen_id(gen_men,1);
end

Ни как не соображу


 
Johnmen ©   (2006-04-07 16:24) [1]

Тут соображать надо после прочтения документации...


 
Desdechado ©   (2006-04-07 16:25) [2]

1. Зачем выбирать 2 поля, чтоб сравнивать потом одно?
2. По условию может оказаться много записей, то будет ошибка multiple rows in singleton select. Может, нужно проверять Max(TMenID) ?
3. if (:men_id<10000) - здесь двоеточие не надо
4. into :men_ID,Men_action; - а вот здесь нужно к каждой переменной

PS from MenT- круто завернул



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

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

Наверх




Память: 0.47 MB
Время: 0.043 c
15-1146638376
Kerk
2006-05-03 10:39
2006.05.28
Яндекс отдаст миллион за хорошее образование


8-1135176215
Woolen
2005-12-21 17:43
2006.05.28
Формат bitmap


2-1146835049
AlexanderMS
2006-05-05 17:17
2006.05.28
Всплывающая подсказка в ListBox


10-1119940455
Scorpio
2005-06-28 10:34
2006.05.28
Сохранение и закрытие Excel


15-1146575726
asdqwer
2006-05-02 17:15
2006.05.28
Интернет в России и на Украине