码迷,mamicode.com
首页 > 数据库 > 详细

SQL执行并返回执行前/后结果

时间:2017-04-09 00:29:35      阅读:259      评论:0      收藏:0      [点我收藏+]

标签:tab   bsp   nbsp   变量   dai   eid   declare   before   har   

1、插入数据,并返回插入的数据:
INSERT INTO TestTB(Province,City) output inserted.Province, inserted.City VALUES(‘广东‘,‘深圳‘)

2、同理,删除数据也是一样的,只不过是使用deleted表罢了。
delete from TestTB output deleted.* where id=1

3、两个结合一起:返回更新前和更新后的数据:
UPDATE TestTB SET Province = ‘湖南‘,City=‘郴州‘ OUTPUT ‘我来自(更新前)‘+ DELETED.Province+DELETED.City as [Before] ,‘我来自(更新后)‘ + Inserted.Province+Inserted.City as [After] WHERE id=1

4、还可以将返回的结果保存在表变量中,这在删除数据,并把删除的数据插入到历史表时很实用
DECLARE @temp TableTABLE(    idint,    Provincevarchar(50),    Cityvarchar(50) )DELETEFROMTestTB OUTPUT deleted.*INTO@tempTableWHEREid>4SELECT*FROM@tempTable
-- 返回更新前的值
UPDATE ppdai_jr_shop.dbo.GeneratorUniqueNo SET suffix=suffix+2  OUTPUT Inserted.suffix WHERE prefix=‘PPDTK‘
-- 返回更新后的值
UPDATE ppdai_jr_shop.dbo.GeneratorUniqueNo SET suffix=suffix+2  OUTPUT DELETED.suffix WHERE prefix=‘PPDTK‘

SQL执行并返回执行前/后结果

标签:tab   bsp   nbsp   变量   dai   eid   declare   before   har   

原文地址:http://www.cnblogs.com/mr-yang-localhost/p/6683297.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!