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

Вниз

Значение первичного ключа   Найти похожие ветки 

 
Kerk ©   (2004-10-18 13:34) [0]

Как можно определить сабж последней добавленной записи?
Способ через @@IDENTITY не катит, ибо не надежно,


 
mcr   (2004-10-18 13:39) [1]

А почему "не катит"
Scope_Identity()
?


 
Kerk ©   (2004-10-18 13:46) [2]

@@IDENTITY AFAIK возвращает значение относительно всей СУБД.

> Scope_Identity()

Не знал о такой. Сейчас в MSDN посмотрю.


 
Reindeer Moss Eater ©   (2004-10-18 13:47) [3]

не катит, ибо не надежно,

Сначала получить значение для PK, потом вставить запись с известным PK.


 
KSergey ©   (2004-10-18 13:48) [4]

Я бы другое спросил: почему "не надежно"?? Это что-то новенькое....
А вообще от версии сервера зависит
Для 7 - только @@IDENTITY, для 2000 - лучше Scope_Identity()

Тольлько надо четко для себя понять что значит и в каком смысле "лучше"


 
Vir   (2004-10-18 13:50) [5]

Я делал по иному.
В таблице вводил поле типа timestamp - оно атоматически правиться MSSQL при изменении записи.
тогда выбрав запись MAX значением этого поля получишь последную редактированную или добавленную запись.


 
Reindeer Moss Eater ©   (2004-10-18 13:57) [6]

тогда выбрав запись MAX значением этого поля получишь последную редактированную или добавленную запись.

Только не обязательно добавленную тобой.


 
Sergey13 ©   (2004-10-18 14:00) [7]

2[5] Vir   (18.10.04 13:50)
>Я делал по иному.
Я извиняюсь, с MSSQL никогда не работал, но не получишь ли ты при таком подходе последную кем-то другим редактированную или добавленную запись


 
Vir   (2004-10-18 14:00) [8]

Reindeer Moss Eater ©   (18.10.04 13:57) [6]
Только не обязательно добавленную тобой.


А не кто и не говорил что нужна запись добавленная именно тобой.


 
KSergey ©   (2004-10-18 14:04) [9]

> Как можно определить сабж последней добавленной записи?

К стати, @@IDENTITY возвращает не значение первичного ключа, а поля, у которого проставлено Identity (автосчетчик)


 
MOA ©   (2004-10-18 14:04) [10]

2Vir - и получим чужую запись в некоторых случаях (записали - кто-то записал в ту же таблицу - считываем по МАХ чужую запись)
>возвращает значение относительно всей СУБД
Зато именно "относительно" текущей сессии. Хотя чаще лучше mcr (18.10.04 13:39) [1]
Удачи!


 
Vir   (2004-10-18 14:08) [11]

Ладно ладно возможно не понял вопрос - просто я подобную процедуру использовал для синхронизации таблиц в разных базах.


 
Пуртик   (2004-10-18 14:24) [12]

select ident_current(<table_name>)


 
Пуртик   (2004-10-18 14:25) [13]

Выполнить в том же запросе на вставку.


 
Kerk ©   (2004-10-19 14:41) [14]


> К стати, @@IDENTITY возвращает не значение первичного ключа,
> а поля, у которого проставлено Identity (автосчетчик)

Ну как раз это я и имел введу.
Всем спасибо. Вопрос решен.


 
Ega23 ©   (2004-10-19 14:44) [15]

Select @X=Max(IsNull(UID))+1 from Table1



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

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

Наверх




Память: 0.49 MB
Время: 0.045 c
6-1091368838
sashapont
2004-08-01 18:00
2004.11.21
Кодировка


1-1099952551
Alek_1
2004-11-09 01:22
2004.11.21
Как правильно копировать динамические масивы?


8-1093110128
Anonymous
2004-08-21 21:42
2004.11.21
fmod или bass?


3-1098783606
OlegL
2004-10-26 13:40
2004.11.21
CleintDataSet


14-1099256045
Herki
2004-10-31 23:54
2004.11.21
скан определённого IP диапазона на наличие Пабов........