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

Вниз

Внесение новой записи в БД   Найти похожие ветки 

 
Larisa   (2002-07-24 13:12) [0]

При внесении новой записи в БД (Interbase) для получения в ключевом столбце уникального значения использую генератор и триггер. Подскажите пожалуйста, как в приложении получить это новое уникальное новое значение ключевого столбца?

Лариса


 
Johnmen ©   (2002-07-24 13:35) [1]

До вставки или после ?
Каковы компоненты доступа ?


 
kaif ©   (2002-07-24 13:45) [2]

Если ключевому полю значение присваивается в триггере, то получить это значение будет невозможно, если только в таблице нет альтернативного уникального ключа, по которому можно было бы перезапросить эту запись (Refresh) на клиент. Поэтому возможны только подхода:
1. Создать альтернативный уникальный ключ, кроме первичного, использовать триггер для получения нового значения первичного ключа и запрос Refresh с применением альтернативного ключа.
2. Сначала запросить новое значение генератора на клиент, а затем уже его вставить без всякого триггера. Компоненты IBX содержат такой механизм.
---------
Я раньше использовал первый метод. В последнее время предпочитаю второй.


 
Val ©   (2002-07-24 14:03) [3]

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


 
AlexSam   (2002-07-24 15:16) [4]

Есть тупой способ - select max(id) from ...


 
kaif ©   (2002-07-24 17:14) [5]

2 AlexSam (24.07.02 15:16)
Этот способ не столько тупой, сколько опасный при многопользовательской работе. И иногда медленный (если записей много). А почему медленный - не знаю.


 
Val ©   (2002-07-24 17:56) [6]

медленный, потому, что это выборка все-таки, а генератор хранит одно, последнее значение.



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

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

Наверх




Память: 0.47 MB
Время: 0.016 c
14-48264
Д_Б
2002-07-19 08:26
2002.08.15
Часы в Win98


7-48342
boogier
2002-06-04 10:17
2002.08.15
Как получить путь к рабочему столу?


3-47991
Dimedrol
2002-07-19 18:18
2002.08.15
Events in IB/FB


1-48080
evgeg
2002-08-04 11:05
2002.08.15
Проблема с Notification


7-48326
z00z
2002-05-22 14:33
2002.08.15
Хочу видеть работу винча