• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    SQL Server误区30日谈 第15天 CheckPoint只会将已提交的事务写入磁盘
    误区 #15:CheckPoint只会将已提交的事务写入磁盘

    错误

    这个误区是由于太多人对日志和恢复系统缺少全面的了解而存在已久。CheckPoint会将自上次CheckPoint以来所有在内存中改变的页写回磁盘(译者注:也就是脏页),或是在上一个CheckPoint读入内存的脏页写入磁盘。无论事务是否已经提交,其所影响的页都会在Checkpoint时写回磁盘。但对于TempDB来说例外,因为TempDB的Checkpoint的事件周期中并不包含将脏页写回磁盘的步骤。

    如果你想了解更多,请阅读下面文章:

        你可以使用如下两个跟踪标记查看CheckPoint是如何工作的。

        为了使用这个跟踪标记,你必须针对所有线程开启,否则你将会在错误日志中什么都看不到。使用DBCC TRACEON (3502, 3504, -1) 针对所有线程开启这两个追踪标记。

        下面的代码可以证明Checkpoint会将未提交的脏页写回磁盘,跟随下面的步骤。

    复制代码 代码如下:

    CREATE DATABASE CheckpointTest; GO USE CheckpointTest; GO
    CREATE TABLE t1 (c1 INT IDENTITY, c2 CHAR (8000) DEFAULT 'a'); CREATE
    CLUSTERED INDEX t1c1 on t1 (c1); GO
    SET NOCOUNT ON; GO
    CHECKPOINT; GO
    DBCC TRACEON (3502, 3504, -1); GO



    下面那个事务会产生10MB的脏页,紧接着进行CheckPoint
    [code]
    BEGIN TRAN; GO INSERT INTO t1 DEFAULT VALUES; GO 1280
    CHECKPOINT; GO
    [html]


    日志如你所见:

     我们可以清楚的看出,在事务没有提交的情况下,脏页依然会被写入磁盘。

    您可能感兴趣的文章:
    • SQL Server误区30日谈 第29天 有关堆碎片的误区
    • SQL Server误区30日谈 第28天 有关大容量事务日志恢复模式的误区
    • SQL Server误区30日谈 第27天 使用BACKUP WITH CHECKSUM可以替代DBCC CheckDB
    • SQL Server误区30日谈 第26天 SQL Server中存在真正的“事务嵌套”
    • SQL Server误区30日谈 第25天 有关填充因子的误区
    • SQL Server误区30日谈 第24天 26个有关还原(Restore)的误区
    • SQL Server误区30日谈 第23天 有关锁升级的误区
    • SQL Server误区30日谈 第22天 资源调控器可以调控IO
    • SQL Server误区30日谈 第21天 数据损坏可以通过重启SQL Server来修复
    • SQL Server误区30日谈 第20天 破坏日志备份链之后,需要一个完整备份来重新开始日志链
    • SQL Server误区30日谈 第19天 Truncate表的操作不会被记录到日志
    • SQL Server误区30日谈 第18天 有关FileStream的存储,垃圾回收以及其它
    • SQL Server误区30日谈 第17天 有关页校验和的误区
    • SQL Server误区30日谈 第16天 数据的损坏和修复
    • SQL Server误区30日谈 第14天 清除日志后会将相关的LSN填零初始化
    • SQL Server误区30日谈 第13天 在SQL Server 2000兼容模式下不能使用DMV
    • SQL Server误区30日谈 第12天 TempDB的文件数和需要和CPU数目保持一致
    • SQL Server误区30日谈 第11天 镜像在检测到故障后瞬间就能故障转移
    • SQL Server误区30日谈 第10天 数据库镜像在故障发生后 马上就能发现
    • SQL Server误区30日谈 第9天 数据库文件收缩不会影响性能
    • SQL Server误区30日谈 第8天 有关对索引进行在线操作的误区
    • SQL Server误区30日谈 第7天 一个实例多个镜像和日志传送延迟
    • SQL Server误区30日谈 第6天 有关NULL位图的三个误区
    • SQL Server误区30日谈 第5天 AWE在64位SQL SERVER中必须开启
    • SQL Server误区30日谈 第4天 DDL触发器就是INSTEAD OF触发器
    • SQL Server误区30日谈 第3天 即时文件初始化特性可以在SQL Server中开启和关闭
    • SQL Server误区30日谈 第2天 DBCC CHECKDB会导致阻塞
    • SQL Server误区30日谈 第1天 正在运行的事务在服务器故障转移后继续执行
    • SQL Server误区30日谈 第30天 有关备份的30个误区
    上一篇:SQL Server误区30日谈 第14天 清除日志后会将相关的LSN填零初始化
    下一篇:SQL Server误区30日谈 第16天 数据的损坏和修复
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    SQL Server误区30日谈 第15天 CheckPoint只会将已提交的事务写入磁盘 SQL,Server,误区,30日谈,第,