Форум: "Базы";
Поиск по всему сайту: 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.017 c
3-80801           SkyR                  2002-04-05 02:50  2002.04.25  
Ошибка - InterBase


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


4-81116           Song                  2002-02-19 17:08  2002.04.25  
WM_POWERBROADCAST отловить жд. режим и обратно


3-80757           VAleksey              2002-04-03 10:16  2002.04.25  
Ошибка при удалении


3-80788           TSV                   2002-04-03 20:11  2002.04.25  
MIDAS