Форум: "Базы";
Поиск по всему сайту: delphimaster.net;
Текущий архив: 2002.04.25;
Скачать: [xml.tar.bz2];




Вниз

Вот вопросик... 


Mikeee   (2002-04-05 09:16) [0]

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



JibSkeart   (2002-04-05 09:26) [1]

А Зачем ??

вообшем можно посмотреть максимальное число и прибавить к нему 1
declare @m int
select @m=Max(Id_key) from Table

select @m=@m+1

select @m

вот посмотри



Johnmen   (2002-04-05 09:35) [2]

>JibSkeart © : Принципиально неверно...
>Mikeee © : Какая БД ?



Mike S   (2002-04-05 09:37) [3]

Действительно зачем???
После того как ты узнал и до того как ты сохранил
может кто-то вставить запись и все уехало:)
>JibSkeart ©
Это работает только если последняя запись не была удалена.



Nikolay M.   (2002-04-05 14:54) [4]

А автоинкрементное поле генерится сервером? Если да, то, естественно, зависит, от сервера. Мы на IB когда-то делали так: создавалась хранимая процедура, которая работала с генератором (переменной) и выдавала при каждом ее вызове значение генератора + 1, а перед добавлением новой записи клиент вызывал эту процедуру, получал очередной ID и прописывал это значение в запросе:
INSERT INTO MyTable (ID, Name) VALUES (:NewGeneratedID, "Mikeee")




Форум: "Базы";
Поиск по всему сайту: delphimaster.net;
Текущий архив: 2002.04.25;
Скачать: [xml.tar.bz2];




Наверх





Память: 0.72 MB
Время: 0.019 c
1-80980           fieldmarshal          2002-04-06 15:56  2002.04.25  
Вопрос по Д6


1-80954           Explorer              2002-04-11 12:14  2002.04.25  
Дайте адресок сайта!


14-81064          knyaz17               2002-03-19 16:34  2002.04.25  
Проблема с Oracle в Win2000!!!


1-81009           Demon Ltd             2002-04-13 00:05  2002.04.25  
Работа повторно с меню


1-80976           Shadow77              2002-04-09 18:43  2002.04.25  
Приложение не должно быть видно в панели задач.