Модераторы: Akina
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Втавить запись и безошибочно получить её ИД 
V
    Опции темы
Иван Человеков
Дата 16.5.2006, 07:05 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 235
Регистрация: 11.3.2006
Где: Минск

Репутация: нет
Всего: 1



Подскажите пожалуйста, как узнать ИД записи, которую только что вставил. Вот как я это делаю:

Код

--Вставляю новый сертификат для товара, делаем его активным
insert Sertif(activ)values(1)

--Ищу ID только что добавленного сертификата
set @maxsert=(select max(sID) from sertif)


Дело в том, что в это время другой пользователь может вставить ещё одну запись, а при поиске максимальной записи, оба будут ссылаться на одну и ту же запись. 
PM ICQ   Вверх
Иван Человеков
Дата 16.5.2006, 12:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 235
Регистрация: 11.3.2006
Где: Минск

Репутация: нет
Всего: 1



Спасибо разобрался:
Код

SET @ID = Scope_Identity()
 
PM ICQ   Вверх
ALKS
Дата 16.5.2006, 12:12 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 354
Регистрация: 22.3.2006

Репутация: 1
Всего: 11



Ну если твой столбец c ID в таблице описан как IDENTITY, то правильнее так:

Код

SET @ID = @@IDENTITY


Но ты должен понимать что возвращаеться ID последнего перед вызовом @@IDENTITY запроса:
"Returns the last-inserted identity value." 
PM   Вверх
Balu
Дата 16.5.2006, 15:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 18
Регистрация: 28.8.2002

Репутация: нет
Всего: 1



Цитата(ALKS @ 16.5.2006,  08:12)
Ну если твой столбец c ID в таблице описан как IDENTITY, то правильнее так:

Код

SET @ID = @@IDENTITY


Но ты должен понимать что возвращаеться ID последнего перед вызовом @@IDENTITY запроса:
"Returns the last-inserted identity value."

@@IDENTITY глобално на всю базу для текущей сессия
Scope_Identity() в рамках текущей хранимки (тригера)

Для примера попробуйте использовать @@IDENTITY в случае когда на INSERT установлен тригер с операцией добавления в другую таблицу с автоинкрементным полем. Вы будете неприятно удивлены, так как получите значение из второй таблички.  
 
PM MAIL   Вверх
ALKS
Дата 16.5.2006, 15:55 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 354
Регистрация: 22.3.2006

Репутация: 1
Всего: 11



Balu, дя я знаю это. но что у нас про тригеры никто не говорил изначально smile 
PM   Вверх
Balu
Дата 17.5.2006, 11:02 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 18
Регистрация: 28.8.2002

Репутация: нет
Всего: 1



Цитата(ALKS @ 16.5.2006,  11:55)
Balu, дя я знаю это. но что у нас про тригеры никто не говорил изначально smile

Это хорошо, что ты знаешь  smile 
Но у меня была ситуация, когда я вставлял логирование изменений спустя полгода, как был разработан модуль.
Логирование сделал через тригер, в бизнес логиу хранимок не лазил. И каково было мое удивление, когда вся логика работы полетела к чертям собачим. С тех пор не люблю я это идентити :-( и не советую другим юзать. 
PM MAIL   Вверх
ALKS
Дата 17.5.2006, 12:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 354
Регистрация: 22.3.2006

Репутация: 1
Всего: 11



SCOPE_IDENTITY() и IDENT_CURRENT() появились только в MS SQL 2000. а раньше выбора особого не было smile
И появились они именно из-за описанной тобой проблемм с триггерами что прямо было написано в "What's New".

Но избегание использования тригееров есть очень хороший постулат, так что наши системы совершенно спокойно жили до этих новшеств и живут без них и дальше. smile 
 
PM   Вверх
Balu
Дата 17.5.2006, 12:57 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 18
Регистрация: 28.8.2002

Репутация: нет
Всего: 1



Цитата(ALKS @ 17.5.2006,  08:01)
Но избегание использования тригееров есть очень хороший постулат, так что наши системы совершенно спокойно жили до этих новшеств и живут без них и дальше. smile

Очень напоминает анекдот про сына программиста и солнце: "... раз работает, то ничего не трогай" 
PM MAIL   Вверх
javas
Дата 25.5.2006, 01:35 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 157
Регистрация: 23.10.2003

Репутация: нет
Всего: 2



Как удалить, не знаю. 

Это сообщение отредактировал(а) javas - 25.5.2006, 01:38
--------------------
 
PM   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "MS SQL"
Akina

Akina

Запрещается!

Публиковать ссылки и обсуждать взлом чего бы то ни было.

  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы составления неспецифических запросов рассматриваются здесь
  • Используйте теги [code=sql][/code] для подсветки кода. Используйтe чекбокс "транслит" (возле кнопок кодов) если у Вас нет русских шрифтов.

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Zloxa, Akina.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | MS SQL Server | Следующая тема »


 




[ Время генерации скрипта: 0.1040 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.