Sql Server output 子句详解

今天在技术群里了解到 output 这个神奇的东东,于是查资料了解了一下:

OUTPUT子句的基本原理是很简单的——它返回由每个INSERT、UPDATE或DELETE命令所影响的记录行。OUTPUT可以在客户端应用程序中返回这些记录行,然后将它们插入到一个持久的或临时的表中,也可以将记录插入到一个表变量中。它的用法就是直接将OUTPUT子句附到任何一个INSERT/UPDATE/DELETE语句后。

  OUTPUT子句中可以引用INSERTED或DELETED虚拟表,这取决于是否想要在数据修改前(DELETED表)修改后(INSERTED表)得到数据。这跟使用触发器去修改数据的操作是很相似的。

  注意不能在一个INSERT语句中引用DELETED,也不能在一个DELETED语句中引用INSERTED,因为这些虚拟表在这两种情况下逻辑上是没有意义的,所以SQL Server不会去创建。

1:insert + output Inserted案例

--创建Test表
CREATE TABLE Test
(
	ID INT NOT NULL IDENTITY(1,1),
	Name VARCHAR(20) NOT NULL 
)

--1:insert+output测试

INSERT INTO dbo.Test
        ( Name )
OUTPUT Inserted.*
VALUES  ( 'ken'
          )

 执行结果如下:

从以上执行结果可以看出output Inserted.* 显示的是Test表插入后的数据。

2:update + output Inserted,deleted 案例

UPDATE dbo.Test
SET Name='Tom'
OUTPUT Deleted.Name AS 更新前,
	   Inserted.Name AS 更新后
WHERE ID=1

执行结果如下:

3:可配合 into 语句使用

--创建一张备份表
CREATE TABLE TEST_BACK
(	
	ID INT NOT NULL IDENTITY(1,1),
	Name VARCHAR(20) NOT NULL 
)

UPDATE dbo.Test
SET Name='Tom'
OUTPUT Deleted.Name
	   INTO TEST_BACK
WHERE ID=1

select * from Test_Back where ID=1

执行后往Test_Back 表中插入的是ID=1 的name 修改前的数据:

  • 9
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值