SQL Server中查询某表相较前一天的增删改记录「建议收藏」

SQL Server中查询某表相较前一天的增删改记录「建议收藏」需求:有一表A,表A中没有记录表数据变动的相关字段,在不修改A表结构的情况 下,查询表A相较前一天的变动数据,包括增、删、改实现:1.

欢迎大家来到IT世界,在知识的湖畔探索吧!

需求:有一表A,表A中没有记录表数据变动的相关字段,在不修改A表结构的情况 下,查询表A相较前一天的变动数据,包括增、删、改

实现:

1.创建表A当天某一时间点的数据快照到表B,如果需要查询多天的差异数据,可以保留多天的快照,每天建一个快照表;

SELECT * INTO B FROM A;

2.将表A与表B full join,并增加一个字段checksum(*),通过checksum(*)字段的比较可以得知update的记录

select * ,case when aa.id is null then 删除,

when bb.id is null then 新增,

when aa.chksum <> bb.chksum then 修改

from (select *,checksum(*) as chksum from a ) aa

full join (select *,checksum(*) as chksum from b ) bb

on aa,id=bb.id

3、清除过期的快照表

注意,checksum()函数可以返回按照表的某一行或一组表达式计算出来的校验和值。 使用

CHECKSUM 来生成哈希值,通过这个值,可以判断一行或表达式的值有没有改变

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://itzsg.com/18261.html

(0)

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们YX

mu99908888

在线咨询: 微信交谈

邮件:itzsgw@126.com

工作时间:时刻准备着!

关注微信