zoukankan      html  css  js  c++  java
  • 从 fn_dbLog 解析操作日志(补充update)

    过去经常听到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/

  • 相关阅读:
    lvs实现故障转移(backup)
    shell计算
    CEGUI 聊天对话框
    SetRenderState 设置渲染状态【转】
    MFC 弹出对话框
    DrawIndexedPrimitive函数的详细解释【转】
    IDirect3DDevice9::Clear 【转】
    manifest 文件错误
    D3DXMatrixLookAtLH 【转】
    D3D中的网格(Mesh)
  • 原文地址:https://www.cnblogs.com/DebugMe/p/7050811.html
Copyright © 2011-2022 走看看