博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
从 fn_dbLog 解析操作日志(补充update)
阅读量:5099 次
发布时间:2019-06-13

本文共 785 字,大约阅读时间需要 2 分钟。

过去经常听到SQL server 日志,可是在提供的界面上看到的Log不是我们想要的,我们想窥探具体的数据操作日志。专业恢复追踪数据库操作日志的软件:ApexSQLLog,偶然发现SQL Server提供了一个系统函数暴露了日志接口。目前可以查阅到insert和delete的代码案例,在前人的基础上增加了update了解析。

代码在这里:https://github.com/jk464479460/SQLSERVERLOG

详细观察代码可以看到原创的地址,进入去细细研究insert和delete,这里不列出了。文章很好的说明了每一列的16进制排列顺序,要点:先固定列,后变长列

关于update的解析,通过DBCC PAGE窥探到每一列的字节位置,结合dbLog中的:PageIDSLotoffset 信息,根据数据库的部分更新原则去解析。

通过解析十六进制,能够揣摩一二微软日志上如何记录的,值得我们借鉴。

 

参考:

https://raresql.com/2012/02/01/how-to-recover-modified-records-from-sql-server-part-1/

https://www.sqlskills.com/blogs/paul/finding-table-name-page-id/

https://learningintheopen.org/2015/12/10/sql-server-fn_dblog-approx-date-time/

https://raresql.com/2012/02/01/how-to-recover-modified-records-from-sql-server-part-2/

转载于:https://www.cnblogs.com/DebugMe/p/7050811.html

你可能感兴趣的文章
ubuntu无法解析主机错误与解决的方法
查看>>
尚学堂Java面试题整理
查看>>
08-【jsp重点】
查看>>
小记:xml画一个爱心。
查看>>
转载:$对象细节详情
查看>>
MySQL表的四种分区类型
查看>>
分页存储过程
查看>>
使用File类递归列出E盘下全部文件
查看>>
总结30个CSS选择器
查看>>
React-Native 学习笔记-Android开发平台-开发环境搭建
查看>>
ios程序编译链接参数 all_load 的 ld duplicate symbol _main 的 bug及修复
查看>>
Spring Boot常用的注解以及含义<持续更新>
查看>>
bzoj 2508: 简单题【拉格朗日乘数法】
查看>>
单元测试图解(二)
查看>>
Git分支操作
查看>>
Java根据html模板创建 html文件
查看>>
7.26
查看>>
dll--二进制层面的复用
查看>>
linux 压缩/解压缩/打包命令
查看>>
守护进程
查看>>