SqlServer数据组织结构
page页
每个页面8KB,连续的8个页面称之为一个区extents,
如:2.18MB的一个DB的区大约有
2.18 MB (2,293,760 字节)=2,293,760b/8kb=280个页面=35个区
一个页只能被一个对象所有
查看数据表中的记录属于哪个文件哪个page页
SELECT top 10
%%physloc%%,
sys.fn_physlocFormatter (%%physloc%%) AS RID
FROM tableName
--注意;在64位系统中sys.fn_physlocFormatter 整理出来的格式有时候不对,需要手工根据physloc来计算,计算的方法是:
以字节为单位倒叙,如
0x0702000001002200倒叙后是
0x0022000100000207
前四位0022表示插槽号2*16+2 = 34,接下来的四位0001表示文件号,余下的00000207表示文件号2*16*16+7 = 519
DBCC TraceOn(3604)
DBCC page(数据库名,1,40995,0)
DBCC TraceOff(3604)
统一区
区中的8个页面为一个对象所有
混合区
区中的8个页面最多可被8个对象共享,新的表或索引从混合类型的区中分配页面。当该表或索引增长到8个页面时(包含表本身数据和它的索引等所有数据大小?),以后所有的分配都使用统一类型的区。
GAM页
全局分配映射(Global Allocation Map),包含页头和一些其它开销外,还有8 000字节或者说64 000bit位可用,每个bit位代表一个区(8个page),0表示已使用,1表示自由区。
64000个bit位代表64000个区64000*8个page页,即2^6 *1000*2^3*8KB=2^12*1000*1000B,大约4G空间。即一个文件的每4GB空间对应一个GAM页面。
SGAM页
共享全局分区,类似GAM一个bit表示一个区,不同的是,他的1表示混合区且有可用空间;1表示未使用或无可用空间
GAM与SGAM关系表:
| 当前使用情况 | GAM比特位设置 | SGAM比特位设置 |
| 全未使用 | 1 | 0 |
| 已全部使用的混合区或统一类型区(统一区) | 0 | 0 |
| 有页面未使用的混合区 | 0 | 1 |
示例:
如何找有可用空间的混合区?
直接找SGAM对应bit为1的区,此时该区对应的GAMbit为0.
提示:
如果没有可用的统一区,则SqlServer会先查找GAM页,分配一个区并作为混合区使用其中的一页。
前8个page页
下一个GAM页面出现在第一个GAM页面(页码为2)以后的每511 230个页面中(大约4G空间后),并且下一个SGAM页面出现在第一个SGAM页面(页码为3)以后的每511 230个页面中。
每一个数据库文件的页码为0的页面是文件头页面,并且每个文件仅有一页(文件头页面,页码为0)。
页码0是头文件页,页码1是页面自由空间页(Page Free Space,PFS)。
sqlserver中前8个数据页顺序都是固定的,所以sqlserver能够很快确认哪些区可用,哪些区不可用。
如下图:
| 第0页 | 第1页 | 第2页 | 第3页 | 第4页 | 第5页 | 第6页 | 第7页 |
| m_type=15 | m_type=11 | m_type=8 | m_type=9 | m_type=0 | m_type=0 | m_type=16 | m_type=17 |
| 头文件页 | PFS页 | GAM页 | SGAM页 | 保留页 | 保留页 | DCM页 | BCM页 |
除了第9页为数据库的BOOT页以外,从第8页到第173页为SQLServer2008内部系统表的相关存储信息,然后从第174页到第279页为未分配页面。因为第一页从0开始,所以刚好280页,即和我们看到的数据库数据文件的大小完全相等。
见前文的运算,数据库大小:2.18 MB (2,293,760 字节)=2,293,760b/8kb=280个页面=35个区。
| 第8页 | 第9页 | 第10页 | ~ | 第173页 | 第174~279页 |
| m_type=1 | m_type=13 | m_type in (1,2,10) | N/A | ||
| Data页 | Boot页 | 主要为内部系统表相关信息 | 未分配 | ||
http://files.cnblogs.com/files/thaughtZhao/InternalsViewerInstaller.rar
DBCC CheckPrimaryfile('D:\MSSQL\Data\GPOSDB.mdf',2)
alter database productdb set online-- 设置联机状态
Select * From sys.dm_exec_connections-- 查看链接
select * from sys.database_files-- 查看文件组
---查看具体数据记录所在的FileID、PageID
SqlServer数据组织结构的更多相关文章
- Oracle、MySql、SQLServer数据分页查询
看过此博文后Oracle.MySql.SQLServer 数据分页查询,在根据公司的RegionRes表格做出了 SQLserver的分页查询语句: 别名.字段 FROM( SELECT row_nu ...
- pandas读取MySql/SqlServer数据 (转)
在 Anacondas环境中,conda install pymssql ,一直报包冲突,所以采用先在 https://www.lfd.uci.edu/~gohlke/pythonlibs/#nump ...
- SQLSERVER数据导入到MYSQL
SQLSERVER数据导入到MYSQL http://hi.baidu.com/luck001221/item/cb4462299f9ea79ab73263d2?qq-pf-to=pcqq.group ...
- 如何暂停sqlserver数据订阅服务
原文:如何暂停sqlserver数据订阅服务 从 Management Studio 启动和停止快照代理或日志读取器代理 在 Management Studio 中连接到发布服务器,然后展开服务器节点 ...
- 使用mongify将sqlserver数据导入到mongodb
最近需要将sqlserver数据导入到mongodb中,在github上搜了一圈,发现两个项目有点适合 mongify sql2mongodb 先试了下sql2mongodb(有个好名字果然有好处啊) ...
- elasticsearch数据组织结构
elasticsearch数据组织结构 1. mapping 1.1. 简介 mapping:意为映射关系,特别是指组织结构.在此语境中可理解为数据结构,包括表结构,表约束,数据类型等 ...
- pandas读取MySql/SqlServer数据
用过的东西总是会忘记,尤其是细节,还是记下来比较靠谱. 读取MySql数据 1 import MySQLdb 2 import pandas as pd 3 4 conn = MySQLdb.conn ...
- SQLServer数据实时同步PostgreSQL
SQLServer数据实时同步至PostgreSQL 前言: 为迎合工作需求有时候传送的数据保存在SQLServer中但由于工作需要需要保存到PostgreSQL中进行处理,本文主要通过在SQLSer ...
- 使用java生成备份sqlserver数据表的insert语句
针对sqlserver数据表的备份工具很多,有时候条件限制需要我们自己生成insert语句,以便后期直接执行这些插入语句.下面提供了一个简单的思路,针对mysql或oracle有兴趣的以后可以试着修改 ...
随机推荐
- CodeForces 404C Ivan and Powers of Two
Ivan and Powers of Two Time Limit:1000MS Memory Limit:262144KB 64bit IO Format:%I64d & % ...
- js:数据结构笔记13--检索算法
顺序查找:也称线性查找,暴力查找的一种 基本格式: var nums = []; for(var i = 0; i < 10; ++i) { nums[i] = Math.floor(Math. ...
- 在Unity3D 4中关联Visual Studio 2012来编写C#
Unity3D自带的MonoDevelop编辑器无论是js还是c#代码提示都很差,很诡异的就是变量名和方法名有的时候提示有的时候不提示.不过用Visual Studio代替MonoDevelop这个问 ...
- 神、上帝以及老天爷[HDU2048]
神.上帝以及老天爷 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total S ...
- 【BZOJ】1303: [CQOI2009]中位数图(特殊的技巧)
http://www.lydsy.com/JudgeOnline/problem.php?id=1303 依旧是题解流,,,不看题解没法活,,,第一眼就是瞎搞,然后就是暴力,显然TLE..题解啊题解. ...
- weblogic sockets 和 thread 问题解决
原创文章,转载须注明出处. 这个问题网上很多答案,可惜没一个能解决.后来发现是weblogic 必须适配JDK 版本. 一般会报这个错误,There are: 5 active sockets, bu ...
- overload和override的区别(转)
overload和override的区别 override(重写) 1.方法名.参数.返回值相同.2.子类方法不能缩小父类方法的访问权限.3.子类方法不能抛出比父类方法更多的异常(但子类方法可以不抛出 ...
- (转载)读取xml中的指定节点的值
/// <summary> /// 读取xml中的指定节点的值 /// </summary> private st ...
- SQL SERVER事务处理
SQL SERVER事务处理 一.事务定义: 事务是单个的工作单元.如果某一事务成功,则在该事务中进行的所有数据更改均会提交,成为数据库中的永久组成部分. 如果事务遇到错误且必须取消或回滚,则所有 ...
- java利用JFreeChart实现各种数据统计图(柱形图,饼图,折线图)
最近在做数据挖掘的课程设计,需要将数据分析的结果很直观的展现给用户,这就要用到数据统计图,要实现这个功能就需要几个第三方包了: 1. jfreechart-1.0.13.jar 2. ...