Классика баз данных - статьи

       

Выборка вставленных данных


Иногда бывает удобно получить в качестве результата выполнения процедуры, вставляющей данные в таблицу, результирующую строку, особенно когда эта строка содержит колонку с уникальным значением. Используя OUTPUT это можно следующим образом: DECLARE @TempBrands TABLE (BrandID int, [Name] nvarchar(32))

INSERT INTO Brands([Name]) OUTPUT inserted.* INTO @TempBrands VALUES(@Name) SELECT * FROM @TempBrands

Отметим, что этот пример показывает работу с одной строкой, поскольку при втавке большого количества строк, поряок следования может быть нарушен (как уже было написано выше, OUTPUT не гарантирует порядок строк) и использовать значения BrandID в вызывающем коде без дополнителных проверок будет проблематично.

Конечно, нет никакой проблемы в том, чтобы получить в результате запроса BrandID, не используя OUTPUT, поскольку обычно все данные уже имеются в вызывающем процедуру коде (они же и передаются в качестве аргументов самой процедуре), за исключением элемента с уникальным значением. INSERT INTO Brands([Name]) VALUES(@Name)

SELECT @@IDENTITY



Содержание раздела