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

Вниз

Проблема с триггером   Найти похожие ветки 

 
AUS_r4nd0m ©   (2004-11-03 20:55) [0]

Привет, Мастера. У меня такая проблема: надо создать триггер, который записывает в поле ID (первичный ключ) уникальное значение с помощью генератора.
Вот запрос на создание:
CREATE TRIGGER TR_ID_Str FOR Strana
ACTIVE
BEFORE INSERT
AS
 BEGIN
  ID_Str=GEN_ID(Gen_Str,1)
 END


Ошибка:
Dynamic SQL Error
SQL error code = -104
Token unknown - line 7, char 1
END
Statement: CREATE TRIGGER TR_ID_Str FOR Strana
ACTIVE
BEFORE INSERT
AS
BEGIN
 ID_Str=GEN_ID(Gen_Str,1)
END


 
AUS_r4nd0m ©   (2004-11-03 20:56) [1]

Что в этом коде не так ???
Заранее спасибо...


 
Vlad ©   (2004-11-03 21:05) [2]

точку с запятой забыл в конце предложения


 
Vlad ©   (2004-11-03 21:08) [3]

CREATE TRIGGER TBI_CLIENTS FOR CLIENTS
ACTIVE BEFORE INSERT POSITION 0
AS
BEGIN
 NEW.CLIENT_ID = GEN_ID(NEWCLIENT, 1);
END


 
AUS_r4nd0m ©   (2004-11-03 21:30) [4]

CREATE TRIGGER TR_ID_Str FOR Strana
ACTIVE
BEFORE INSERT POSITION 0
AS
 BEGIN
  New.ID_Str=GEN_ID(Gen_Str,1);
 END


Теперь вот что пишет:
Dynamic SQL Error
SQL error code = -104
Unexpected end of command


 
Vlad ©   (2004-11-03 21:40) [5]

навскидку все вроде верно, хотя почитай еще вот это:
http://www.ibase.ru/devinfo/generator.htm#using


 
AUS_r4nd0m ©   (2004-11-03 21:48) [6]

А если в запросах из клиентского приложения вызывать генератор, тоже самое ведь получится? Странно все это, вроде до этого делал работало....


 
Johnmen ©   (2004-11-03 22:09) [7]

>AUS_r4nd0m ©  (03.11.04 21:30) [4]

Откуда выполняется сиё ?


 
AUS_r4nd0m ©   (2004-11-03 22:10) [8]

> Johnmen
IBConsole


 
AUS_r4nd0m ©   (2004-11-03 22:13) [9]

Вот моя ася стучитесь 309462263, иначе это будет долго...


 
Johnmen ©   (2004-11-03 22:20) [10]

У меня нет аси. И не будет :)

SET TERM ^ ;

CREATE TRIGGER TR_ID_Str FOR Strana
ACTIVE
BEFORE INSERT POSITION 0
AS
BEGIN
New.ID_Str=GEN_ID(Gen_Str,1);
END ^

SET TERM ; ^

СтОит хелпы почитать...:)


 
AUS_r4nd0m ©   (2004-11-03 22:32) [11]

Спасибо, работает. А что такое SET TERM ^ ;?


 
Johnmen ©   (2004-11-03 22:59) [12]

Изменю себе и не буду посылать в хелп...:)
ИБКонсоль, как и другие аналогичные штуки, позволяет выполнять ряд последовательно написанных запросов (скрипт), которые отделяются ;
А у тебя идет создание триггера с его телом - содержимое его есть программа на процедурном языке. В котором языковые конструкции ("команды") также отделяются ;
Интерпритатор должен отличить эти, по сути разные, ; ?
Должен.
Для это сущ-ет опция команды SET под назв. TERM, которая говорит, что "дальше интерпритируем знак x как знак у, SET TERM x y".

Ну дальше понятно, надеюсь...:)


 
Johnmen ©   (2004-11-03 23:26) [13]

>Johnmen ©  (03.11.04 22:59) [12]

У тебя, дружок, ошибочка. ИНТЕРПРЕТАЦИЯ.
:)))


 
AUS_r4nd0m ©   (2004-11-04 00:44) [14]

Спасибо за объяснение. Теперь буду знать


 
Deniz ©   (2004-11-04 06:31) [15]

...
BEGIN
if (NEW.ID_Str is null) then <------ добавить
 New.ID_Str=GEN_ID(Gen_Str,1);
END



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

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

Наверх




Память: 0.5 MB
Время: 0.054 c
14-1100773948
Drakon
2004-11-18 13:32
2004.12.05
Латинские крылатые выражения


6-1095851631
MSergey
2004-09-22 15:13
2004.12.05
Получение данных из Интернета


1-1101271504
DDDeN
2004-11-24 07:45
2004.12.05
Получить строку из TStringGrid


14-1100693022
infom
2004-11-17 15:03
2004.12.05
Кто нидь в этом участвет ?


1-1100755828
main
2004-11-18 08:30
2004.12.05
Файловая система и TREEVIEW