Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2003.12.26;
Скачать: [xml.tar.bz2];

Вниз

IB: TRIGGER DOESN T WORK   Найти похожие ветки 

 
introvert   (2003-12-02 19:21) [0]

Добрый вечер, мастера! Новичок в SQL, поэтому (ли) возникает вопрос следующего содержания:

Создаю таблицу в интербазе, пытюсь повесить, прям как в книге, триггер на добавление записи и, таким образом, генерировать значение идентификатора. Создал генератор, далее - экстракт метаданных, согласно которого, как мне казалось, при добавлении новой записи - вводим значение в поле TCODE, значение поля ID должно сгенериться и все ОК. Не тут-то было. В чем проблема, помогите разобраться!

/* Domain definitions */
CREATE DOMAIN "PRMKEY" AS INTEGER
CHECK (VALUE>=0) NOT NULL;

/* Table: TMAINDATA, Owner: SYSDBA */

CREATE TABLE "TMAINDATA"
(
"ID" "PRMKEY",
"TCODE" VARCHAR(16) CHARACTER SET WIN1251
);
SET TERM ^ ;

/* Triggers only will work for SQL triggers */

CREATE TRIGGER "CREATE_ID" FOR "TMAINDATA"
ACTIVE BEFORE INSERT POSITION 0
AS BEGIN
if (NEW.ID is NULL) THEN NEW.ID = GEN_ID(TMAINDATA_ID_GEN, 1);
END
^

COMMIT WORK ^
SET TERM ;^


 
Zacho   (2003-12-02 20:03) [1]

Что именно значит "Не тут-то было" ? Разьясни подробно, телепатов нет. У тебя все сделано правильно, только CHECK -лишний, достаточно NOT NULL.
И почитай http://www.ibase.ru/devinfo/generator.htm - вполне возможно, что после этого твой вопрос решится.


 
introvert   (2003-12-02 20:45) [2]

А проблема такая - кричит, что поле ID не может быть пустым. Field ID cannot be null.
Почитаю.


 
Zacho   (2003-12-02 21:08) [3]


> introvert (02.12.03 20:45) [2]

TField.Required:=false;
И статью почитай обязательно, там все подробно описано.
И сразу же (а не после напоминания) в вопросе приводи текст сообщения об ошибке, причем оригинальный, и точный, а еще крайне желательно - версию IB и используемые тобой компоненты доступа.
И еще - прочитай книгу "Мир Interbase" Востриков, Ковязин.



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

Форум: "Базы";
Текущий архив: 2003.12.26;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.44 MB
Время: 0.008 c
4-86598
Serhio
2003-10-31 19:24
2003.12.26
Поиск окна


14-86560
Дмитрий_Б
2003-12-02 11:44
2003.12.26
Вопрос знатокам 1С.


3-86282
scorpi
2003-12-02 14:29
2003.12.26
Добавление поля в таблицу


3-86267
Andriy Tysh
2003-12-03 10:29
2003.12.26
Master-Detail


3-86291
ploxish
2003-12-01 11:23
2003.12.26
Interbase & Generator





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский