SQL Server :理解BCM页

本文涉及的产品
云数据库 RDS SQL Server,独享型 2核4GB
简介: 原文:SQL Server :理解BCM页今天我们来讨论下批量更改映射(Bulk Changed Map:BCM)页,还有大容量日志恢复模式( bulk logged recovery model )如何运作的。
原文: SQL Server :理解BCM页

今天我们来讨论下批量更改映射(Bulk Changed Map:BCM)页,还有大容量日志恢复模式( bulk logged recovery model )如何运作的。

批量更改映射(Bulk Changed Map:BCM):SQL Server使用BCM页来跟踪自上次完全备份后,被大容量日志操作修改的区。在数据库文件里,BCM页是第7页。BCM对每个跟踪的页都有一个位。如果这个位标记是1,表示对应区在上次日志备份后因为大容量日志操作而修改。如果这个位标记为0,表示在上次日子备份后因为大容量日志操作而未被修改。一个BCM页可以保存近64000个区的信息。BCM页在每511232页重复一次。一个BCM页可以跟踪63904个区的信息。第2个BCM页会出现在第511239页。

在所有数据库里你都可以找到BCM页,但只有数据库进行大容量日志恢复模式时才会用到。在这个恢复模式里,当进行日志备份时,SQL Server会扫描BCM页,在里面查找在使用事务日志进行日志备份时标记为已经更改的区。这让SQL Server进行大容量日志恢复是可回滚的,如果是数据库是从数据库备份中还原,并且有一系列的事务日志备份。在大容量日志恢复模式里,大容量日志操作包括BCP,Bulkinsert, Select Into等在事务日志里是最低程度写入日志的,并通过BCM页对修改过的区进行跟踪。这让SQL Server 进行大容量操作时有更好的性能。

BCM页与简单还原和完全还原模式无关。在简单和完整还原模式里,大容量日志操作被当作完整日志操作。简而言之,在简单和大容量日志还原模式里,BCM页会通过大容量日志操作来跟踪所发生的改变。

我们用一个例子来理解下:新建一个空数据库,修改数据库还原模式为大容量日志恢复模式,将数据库进行备份,最后用DBCC PAGE来查看BCM页的信息。

1 CREATE DATABASE BCMdb
2 GO
3 ALTER DATABASE BCMdb SET RECOVERY BULK_LOGGED
4 BACKUP DATABASE BCMdb TO DISK='D:\BCMdb.bak'
5 GO
6 DBCC TRACEON(3604)
7 DBCC PAGE('BCMdb',1,7,3)

可以清楚看到,没有看到因大容量日志操作而造成的分区改变。我们来执行一个大容量日志操作。

1 SELECT * INTO BCMdb..SalesOrderDetail FROM AdventureWorks2008R2.sales.SalesOrderDetail
2 DBCC TRACEON(3604)
3 DBCC PAGE('BCMdb',1,7,3)

可以看到,有2条被标记为MIN_LOGGED 。第1条是因为IAM页中的改变,第2条是因为SELECT INTO插入的数据操作。现在当我们进行日志备份,SQL Server会备份事务日志,就是BCM页里标记为改变的区对应的事务日志。日志备份后,BCM页的相关区,因大容量日志操作而打上改变的标记,会打上未改变的标记。我们来进行下日志备份。

1 BACKUP LOG BCMdb TO DISK='D:\BCMdblog.trn'
2 GO
3 DBCC PAGE('BCMdb',1,7,3)

注意,BCM页不会因为完整或差异备份做相应改变。事务日志备份是刚才事务日志的基础。SQL Server应该知道2个事务日志之间所发生的改变。如果差异或完整备份清空了BCM页里的标记,下个事务日志备份就不能跟踪或还原上一个日志备份和完整或差异备份之间的改变。简而言之,一个完整或差异备份不会打断事务日志备份链。

 

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
目录
相关文章
|
7天前
|
SQL 人工智能 算法
【SQL server】玩转SQL server数据库:第二章 关系数据库
【SQL server】玩转SQL server数据库:第二章 关系数据库
45 10
|
1月前
|
SQL 数据库 数据安全/隐私保护
Sql Server数据库Sa密码如何修改
Sql Server数据库Sa密码如何修改
|
2月前
|
SQL 算法 数据库
【数据库SQL server】关系数据库标准语言SQL之数据查询
【数据库SQL server】关系数据库标准语言SQL之数据查询
95 0
|
2月前
|
SQL 算法 数据库
【数据库SQL server】关系数据库标准语言SQL之视图
【数据库SQL server】关系数据库标准语言SQL之视图
76 0
|
2月前
|
SQL 人工智能 算法
【数据库SQL server】传统运算符与专门运算符
【数据库SQL server】传统运算符与专门运算符
68 0
|
17天前
|
SQL
启动mysq异常The server quit without updating PID file [FAILED]sql/data/***.pi根本解决方案
启动mysq异常The server quit without updating PID file [FAILED]sql/data/***.pi根本解决方案
15 0
|
7天前
|
SQL 算法 数据库
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
【SQL server】玩转SQL server数据库:第三章 关系数据库标准语言SQL(二)数据查询
62 6
|
7天前
|
SQL 存储 数据挖掘
数据库数据恢复—RAID5上层Sql Server数据库数据恢复案例
服务器数据恢复环境: 一台安装windows server操作系统的服务器。一组由8块硬盘组建的RAID5,划分LUN供这台服务器使用。 在windows服务器内装有SqlServer数据库。存储空间LUN划分了两个逻辑分区。 服务器故障&初检: 由于未知原因,Sql Server数据库文件丢失,丢失数据涉及到3个库,表的数量有3000左右。数据库文件丢失原因还没有查清楚,也不能确定数据存储位置。 数据库文件丢失后服务器仍处于开机状态,所幸没有大量数据写入。 将raid5中所有磁盘编号后取出,经过硬件工程师检测,没有发现明显的硬件故障。以只读方式将所有磁盘进行扇区级的全盘镜像,镜像完成后将所
数据库数据恢复—RAID5上层Sql Server数据库数据恢复案例
|
11天前
|
SQL 安全 Java
SQL server 2017安装教程
SQL server 2017安装教程
14 1
|
24天前
|
SQL 存储 Python
Microsoft SQL Server 编写汉字转拼音函数
Microsoft SQL Server 编写汉字转拼音函数