使用数据层统一管理缓存的时候遇到一个问题就是update delete 的缓存处理
思考,查找,寻求到了一个解决办法分享如下:
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 @tempTable TABLE(
id int,
Province varchar(50),
City varchar(50)
)
DELETE FROM TestTB OUTPUT deleted.* INTO @tempTable
WHERE id > 4
SELECT * FROM @tempTable
感谢作者
本文分享了使用数据层统一管理缓存时,针对INSERT、DELETE和UPDATE操作的SQL技巧,包括返回插入、删除和更新前后数据的方法,以及将返回结果保存在表变量中的实用策略。
1387

被折叠的 条评论
为什么被折叠?



