如何让Sql 执行完前面的语句再执行后面的语句
发布网友
发布时间:2022-04-09 19:08
我来回答
共2个回答
懂视网
时间:2022-04-09 23:29
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
热心网友
时间:2022-04-09 20:37
SQL 是先执行完前面的语句,再执行后面的语句啊,你的语句写得我很有疑问。
1. 当xiti(ti,da)插入第一条记录的时候,那么da只有一个,你已经赋给@d1了,怎么还能再拿到不等于@d1的@d2,@d3,@d4?他们肯定是null
2. 当xiti(ti,da)插入很多记录的时候,假设da是很多种的,那么你用select top 1 @d2=da from xiti where da not in(@d1) order by newid() ;的时候,没有指定ti,也就是会拿到其他ti的da,这是否合理?
3.select top 1 @d2=da from xiti where da not in(@d1) order by newid() ;,order by newid()怎么理解?