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

Вниз

Проблема с генераторами в IB->Delphi   Найти похожие ветки 

 
MyVeryShortLogin ©   (2002-08-26 12:13) [0]

создал генератор, триггер:
CREATE GENERATOR "IDNO_GEN";

CREATE TRIGGER "CREATE_ID" FOR "TEST"
ACTIVE BEFORE INSERT POSITION 0
AS
BEGIN
NEW.ID = GEN_ID(IDNO_GEN, 1);
END

если вставка происходит SQL запросом (insert into...), то все ОК,
а если через TDBGid в Delphi, то вылетает еггог-а "Field "ID" must have value", т.е. триггер не запускается, как лечить?


 
Reindeer Moss Eater   (2002-08-26 12:18) [1]

Триггер запускается.
Установи свойство Required для этого TField в False


 
Leran2002 ©   (2002-08-26 12:22) [2]

Отрывок из статьи на www.ibase.ru:
использование хранимой процедуры не всегда удобно - BDE может решить, что процедура вероятно изменяет какие-то данные на сервере, и в режиме autocommit завершит текущую транзакцию, что вызовет перечитывание данных TTable и TQuery. Более простым способом является получение значения генератора при помощи запроса:
SELECT GEN_ID(NEWCLIENT, 1) FROM RDB$DATABASE

При этом, если запрос помещен например в Query2, текст в BeforePost будет следующим:

begin
if DataSource.State = dsInsert then
begin
Query2.Open;
ClientTable.FieldByName("CLIENT_ID").asInteger:=
Query2.Fields[0].asInteger;
Query2.Close;
end;
end;



 
MyVeryShortLogin ©   (2002-08-26 13:16) [3]

2 Reindeer Moss Eater поле ID у меня NOT NULL PRIMARY KEY
2 Leran2002 сенкс, заработало, только приращивает с шагом 2, но это мелочи, хотя если знаешь в чем дело, то буду благодарен.



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

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

Наверх




Память: 0.47 MB
Время: 0.02 c
1-50790
jcrush
2002-09-02 18:19
2002.09.16
код из Help a а глючит до нельзя :( может где нить ошибка???


1-50823
NAU
2002-09-04 05:48
2002.09.16
Как определить кем создан файл?


7-50991
DNT
2002-07-05 09:45
2002.09.16
Можно ли компоненты хранить в DLL?


1-50765
kay
2002-09-04 23:03
2002.09.16
TTreeNode


1-50686
Лана Розанова
2002-09-04 16:03
2002.09.16
Фильтры