原文: sql server 帶有OUTPUT的INSERT,DELETE,UPDATE OUTPUT是SQL SERVER2005的新特性.可以從資料修改語句中傳回輸出.可以看作是"傳回結果的DML".INSERT,DELETE,UPDATE均支援OUTPUT子句.在OUTPUT子句中,可以引用特殊表inserted和deleted.使用inserted和deleted表與在觸發器中使用的非常相似.
在INSERT,DELETE,UPDATE中OUTPUT的差別
1.對于INSERT,可以引用inserted表以查詢新行的屬性.
2.對于DELETE,可以引用deleted表以查詢舊行的屬性.
3.對于UPDATE,使用deleted表查詢被更新行在更改前的屬性,用inserted表辨別被更新行在更改後的值.
輸出方式:
1.可以輸出給調用方(用戶端應用程式)
2.輸出給表
3.兩者皆可.
應用:
一.帶有OUTPUT的INSERT的應用
對于包含自增列的表執行多行insert語句,同時想知道新的辨別值時,在INSERT中使用OUTPUT子句非常友善.對于單行INSERT語句,這不成問題:SCOPE_IDENTITY函數即可實作.
- -- Generating Surrogate Keys for Customers
- USE tempdb;
- GO
- IF OBJECT_ID('dbo.CustomersDim') IS NOT NULL
- DROP TABLE dbo.CustomersDim;
- CREATE TABLE dbo.CustomersDim
- (
- KeyCol INT NOT NULL IDENTITY PRIMARY KEY,
- CustomerID NCHAR(5) NOT NULL,
- CompanyName NVARCHAR(40) NOT NULL,
- /* ... other columns ... */
- );
- -- Insert New Customers and Get their Surrogate Keys
- DECLARE @NewCusts TABLE
- CustomerID NCHAR(5) NOT NULL PRIMARY KEY,
- KeyCol INT NOT NULL UNIQUE
- INSERT INTO dbo.CustomersDim(CustomerID, CompanyName)
- OUTPUT inserted.CustomerID, inserted.KeyCol
- INTO @NewCusts
- -- OUTPUT inserted.CustomerID, inserted.KeyCol
- SELECT CustomerID, CompanyName
- FROM Northwind.dbo.Customers
- WHERE Country = N'UK';
- SELECT CustomerID, KeyCol FROM @NewCusts;
注意代碼中被注釋掉的第二個OUTPUT子句,後面沒有INTO子句.如果還要輸出傳回給調用方,取消注釋即可.這樣,INSERT語句将包含兩個OUTPUT子句.
示例2.
- USE AdventureWorks;
- GO
- CREATE TABLE TestTable (ID INT, TEXTVal VARCHAR(100))
- DECLARE @TmpTable TABLE (ID INT, TEXTVal VARCHAR(100))
- INSERT TestTable (ID, TEXTVal)
- OUTPUT Inserted.ID, Inserted.TEXTVal INTO @TmpTable
- VALUES (1,'FirstVal')
- VALUES (2,'SecondVal')
- SELECT * FROM @TmpTable
- SELECT * FROM TestTable
- DROP TABLE TestTable
- OUTPUT Inserted.ID, Inserted.TEXTVal
二.帶有OUTPUT的DELETE的應用.
如果要删除資料的同時,還需要記錄日志,或者歸檔資料.在DELETE中使用OUTPUT子句在适合不過了.
- DELETE
- FROM TestTable
- OUTPUT Deleted.ID, Deleted.TEXTVal INTO @TmpTable
- WHERE ID IN (1,2)
三.帶有OUTPUT的UPDATE的應用
- DECLARE @TmpTable TABLE (ID_New INT, TEXTVal_New VARCHAR(100),ID_Old INT, TEXTVal_Old VARCHAR(100))
- UPDATE TestTable
- SET TEXTVal = 'NewValue'
- OUTPUT Inserted.ID, Inserted.TEXTVal, Deleted.ID, Deleted.TEXTVal INTO @TmpTable
- GO