Форум: "Базы";
Текущий архив: 2002.08.15;
Скачать: [xml.tar.bz2];
ВнизВнесение новой записи в БД Найти похожие ветки
← →
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;
Скачать: [xml.tar.bz2];
Память: 0.45 MB
Время: 0.007 c