欢迎大家来到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