Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 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
6-48242
Ampersand
2002-05-31 07:42
2002.08.15
Запретить работу по TCP/IP


3-47928
Explorer
2002-07-25 10:11
2002.08.15
Запрос на Max значения


14-48246
mvg_first
2002-07-18 19:28
2002.08.15
Кто и как использует продукты Rational


4-48350
VJar
2002-06-07 00:56
2002.08.15
Проблема с получением окон в Taskbar


4-48372
z_z
2002-06-10 23:03
2002.08.15
Форма на рабочем столе





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский