Форум: "Базы";
Поиск по всему сайту: 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.038 c
4-81103           hair_fly              2002-02-19 18:06  2002.04.25  
Как отличить NT от 2000 ?


3-80766           merr                  2002-04-04 12:55  2002.04.25  
paradox-базы в Delphi


1-80967           DenKop                2002-04-11 13:35  2002.04.25  
Сообщение другой программе.


1-80863           Chainik               2002-04-13 15:15  2002.04.25  
Функциональные клавиши


3-80782           Mikeee                2002-04-03 16:21  2002.04.25  
Что бы это значило :