Главная страница
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-1146055921
Nic
2006-04-26 16:52
2006.05.28
Что для России означает снижение курса доллара?


2-1147154902
Sergey Masloff
2006-05-09 10:08
2006.05.28
Проблема с кодировками. Написал плагин к Outlook но сабж...


4-1141714583
Новичоккк
2006-03-07 09:56
2006.05.28
Перехватить вызов функции из DLL


8-1134291419
race1
2005-12-11 11:56
2006.05.28
Midi to wav


1-1145272681
petun
2006-04-17 15:18
2006.05.28
сохранение данных формы в doc формате