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

Вниз

TIBDataSet...   Найти похожие ветки 

 
First_May ©   (2002-12-19 09:50) [0]

Здравствуйте! Записал в TIBDataSet в свойство InsertSQL следующий текст:
INSERT INTO MOL(COD, CODP, DEF, DEFS)
VALUES(:NEW_COD, :NEW_CODP, :NEW_DEF, :NEW_DEFS)
Поле COD является автоинкрементным. Но при добавлении новой записи выскакивает ошибка, то есть COD не получает значение. Как этого избежать???


 
Prooksius ©   (2002-12-19 09:56) [1]

Можно написать триггер на вставку и заполнять поле там, а на клиенте его не изменять.


 
First_May ©   (2002-12-19 10:07) [2]

Я об этом думал, но мне надо использовать этот код в связанных таблицах... Ну а вообще кто нибудь сталкивался с этим вопросом еще?


 
Alexandr ©   (2002-12-19 10:09) [3]

все сталкивались.
Но непонятно, чего конкретно ты хочешь избежать...


 
Prooksius ©   (2002-12-19 10:11) [4]

В таком случае самое лучшее - Query.SQL := select gen_id(mygenerator, 1) RecNo from rdb$datadase
При вставке выполнять эту Query и читать значение поля RecNo.
Тогда ты будешь этот номер знать и в клиенте.
Я так и делаю. ИМХО самый лучший способ.


 
First_May ©   (2002-12-19 10:16) [5]

А как Alexandr © (19.12.02 10:09) решает этот вопрос? :)


 
Johnmen ©   (2002-12-19 10:30) [6]

Если надо использовать в связ.табл., то наиболее предпочтительней заранее получать ID.
см. Prooksius © (19.12.02 10:11)
или с помощью ХП (я предпочитаю так)


 
First_May ©   (2002-12-19 10:54) [7]

Спасибо всем!



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

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

Наверх




Память: 0.47 MB
Время: 0.018 c
4-37472
Unknown user
2002-11-26 19:57
2003.01.13
Масштабирование текста


1-37213
jen_bond
2002-12-30 21:41
2003.01.13
Запись информации в ini


14-37301
Song
2002-12-22 10:43
2003.01.13
Romkin, поздравляю с днём варенья!


3-36920
asusfi
2002-12-17 13:37
2003.01.13
Lookup поле


3-36945
BIN
2002-12-16 07:56
2003.01.13
Oracle умер