Главная страница
    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
1-48076
Дмитрий Иванов
2002-08-05 02:04
2002.08.15
проблема с созданием компонет в run-time е


4-48369
izved
2002-06-05 17:57
2002.08.15
Нужна помощь


1-48056
pentium
2002-08-03 09:46
2002.08.15
Мочилка троянцев, вирусов, и.т.п


3-47996
grandad
2002-07-26 10:16
2002.08.15
Нужно поставить прогу, работающую с БД accesss (mdb) от MS Office


3-47983
Glonia Zbanov
2002-07-26 15:24
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
Английский Французский Немецкий Итальянский Португальский Русский Испанский