那就是内存中被修改的数据写回到磁盘后,也就意味着磁盘中的数据版本和日志中的数据操作已经同步了。当然也就意味着如果这个时候系统崩溃了,SQL Server就不需要再恢复了。
不过如果真的这个时候崩溃了,那么SQL Server怎么知道这些日志操作的数据已经写到磁盘了呢,所以SQL Server还有一个概念。
这个概念就是CheckPoint。
当SQL Server将一些被修改过的数据(术语叫Dirty Data)写回到磁盘后(这个操作的术语叫Flush),SQL Server会在日志中留下一个标记,以表示这个标记前的数据已经都被写到磁盘中了,而这个标记就叫做CheckPoint。
因此我们可以这么说,CheckPoint代表着一次Flush操作。
SQL Server会在以下情况下触发CheckPoint,也就是进行Flush:
SQL Server在正常停止服务的时候
日志中需要进行恢复的操作要花费超过Recovery Interval的时间时
SQL Server可用内存不足的情况下
管理员手动递交CheckPoint命令的时候
当日志文件中的数据超过70%ITPUB个人空间~4g8H1Z g,Q%];A