Главная страница
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.023 c
1-37159
Leny
2002-12-29 12:53
2003.01.13
завершение Windows


1-37011
Dmitriy_R
2003-01-01 14:24
2003.01.13
Каталоги, файлы, и т.д.


1-37138
Yurko
2002-12-29 03:22
2003.01.13
IconChange


4-37452
Славик@Майл2к.ру
2002-11-24 07:38
2003.01.13
Перехват сообщения об ошибке и ...........


14-37341
OlDemon
2002-12-24 08:39
2003.01.13
Вирусы для сотовых