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

Вниз

Как узнать значение autoincrement поля в IB5   Найти похожие ветки 

 
Nikola62   (2003-01-29 00:51) [0]

В таблице имеется поле с автоувеличением (через триггер). Как после добавления новой записи в таблицу узнать значение этого поля?


 
Наталия ©   (2003-01-29 05:44) [1]

Можно узнать ДО добавления записи в таблицу, а затем добавить запись с этим значением.


 
AlexSerp ©   (2003-01-29 09:57) [2]

Сделать запрос поиска записи в таблице уникальному ключу, а там и взять значение нужного поля.
Если нет уникального поля, то можно сделать запрос по нескольким полям, которые будут однозначно указывать на эту запись.

Саня


 
Anatoly Podgoretsky ©   (2003-01-29 10:04) [3]

AlexSerp © (29.01.03 09:57)
Не по нескольким поля, а по всем.

Nikola62 (29.01.03 00:51)
Если тебе так нужен этот номер в тот момент, то читай Наталия © (29.01.03 05:44), у тебя в данном случае неверный дизайн.


 
Johnmen ©   (2003-01-29 10:19) [4]

Еще одна разновидность решения - вставлять только с помощью ХП, которая будет возвращать необходимое значение...


 
AlexSerp ©   (2003-01-29 10:31) [5]

Anatoly Podgoretsky © (29.01.03 10:04)
Согласен.

Саня


 
passm ©   (2003-01-29 10:37) [6]

Anatoly Podgoretsky © (29.01.03 10:04)> Не обязательно неверный дизайн.
Если сидит куча пользователей и набирают документы (приход, расход...) вариант с поиском по всем полям в данном случае не подходит, поскольку теоретически возможны совпадения.
Здесь позвольте отойти от IB и генераторов. Мне понравилось решение в DB2. Имеется функция GENERATE_UNIQUE(), которая всегда возвращает уникальное значение типа CHARACTER(13). Для генерирования результата берется CURRENT TIMESTAMP, номер сесси пользователя и немного случайной информации. Т.о. при создании нового документа беру:
SELECT NUM.NUM
FROM (VALUES(GENERATE_UNIQUE())) AS NUM(NUM)
И идентификатор для уникального значения и дальнейшего поиска по нему готов.
К чему это я: может, можно написать подобную UDF для IB и использовать подобный механизм в таблицах, где поиск по неключевым полям не гарантирован.


 
JibSkeart ©   (2003-01-29 10:43) [7]

А можно еще из таблички брать максимальный ключ
а новый ключ инкременировать на 1


 
passm ©   (2003-01-29 10:52) [8]

JibSkeart © (29.01.03 10:43)> Только в однопользовательском режиме.



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

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

Наверх




Память: 0.48 MB
Время: 0.016 c
1-38333
anaTolik
2003-02-03 18:00
2003.02.13
Загрузка проекта.


1-38286
Ash
2003-02-05 18:37
2003.02.13
DrawFocusRect


9-38000
Ev_genus
2002-05-10 12:41
2003.02.13
Чем DelphiX хуже Direct API. (Это не вопрос)


1-38326
ZeaLoT
2003-02-03 16:48
2003.02.13
Интерпретатор, структуры данных.


6-38411
Felix the cat
2002-12-18 22:23
2003.02.13
1 Serv+N Clients