Главная страница
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.068 c
2-1174289320
Нуб
2007-03-19 10:28
2007.04.08
StringGrid


2-1174050233
Один
2007-03-16 16:03
2007.04.08
IB7.1 очень большой расход памяти сервером


2-1173979067
Malik
2007-03-15 20:17
2007.04.08
Вопрос к StringGrid у


2-1174024559
rommel
2007-03-16 08:55
2007.04.08
Свойство align


2-1173896890
Malik
2007-03-14 21:28
2007.04.08
Проблема с Delphi