玖叶教程网

前端编程开发入门

SQL Server中查询某表相较前一天的增删改记录

需求:有一表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 来生成哈希值,通过这个值,可以判断一行或表达式的值有没有改变

发表评论:

控制面板
您好,欢迎到访网站!
  查看权限
网站分类
最新留言