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

Вниз

Как в *.gdb в связанные таблицы добавить записи   Найти похожие ветки 

 
AlexeyMir   (2007-01-22 11:51) [0]

Я использую базу *.gdb на Interbase5
Подскажите, у меня есть две связанные таблицы в отношении один-ко-многим RC_MNT(содержание документа) и HD_MNT(заголовок документа), причем поле ID_MNT таблицы RC_MNT ссылается на поле ID таблицы HD_MNT, а на ID таблицы HD_MNT стоит автоинкремент построенный на генераторе.
Мне нужно в одной транзакции добавить строку в HD_MNT, я это делаю так: insert into HD_MNT(num,dat) values(0,"now"), ID не указываю, он сам формируется, после этого мне нужно узнать какой же ID сформировался что бы указать его в RC_MNT в поле ID_MNT

  IBTransaction1.StartTransaction;
   IBQuery1.SQL.Clear;
   IBQuery1.SQL.ADD("insert into HD_MNT(num,dat)");
   IBQuery1.SQL.ADD("values(0,"now")");
   IBQuery1.ExecSQL;

   IBQuery1.SQL.Clear;
   IBQuery1.SQL.ADD("insert into RC_MNT(id_mnt,fg,df,...)");
   IBQuery1.SQL.ADD("values(???,fg,df,...)");
   IBQuery1.ExecSQL;
  IBTransaction1.Commit;


 
unknown ©   (2007-01-22 12:09) [1]


> AlexeyMir   (22.01.07 11:51)

Надо просто предварительно получать значение генератора для HD_MNT.num
отдельным запросом:
select gen_id(тут_имя_генератора,1) from rdb$database


 
Johnmen ©   (2007-01-22 12:40) [2]

На эту тему существует несколько способов решения. Но суть их всех сводится к получению ID до вставки записи.
(исключая случай, когда кроме суррогатного есть и натуральный ключ или уникальный индекс)



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

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

Наверх




Память: 0.47 MB
Время: 0.031 c
15-1173605122
php-er
2007-03-11 12:25
2007.04.08
не присваеваится значение переменной.


15-1173794863
ArtemESC
2007-03-13 17:07
2007.04.08
Разместил я резюме но job.ru


3-1169031100
kyn66
2007-01-17 13:51
2007.04.08
Не открываются базы Visual FoxPro


5-1150975100
Isaak
2006-06-22 15:18
2007.04.08
TObj = class(TGraphicControl)


15-1174058986
oldman
2007-03-16 18:29
2007.04.08
Пожелай мне удачи в бою...