1.行的总大小:

Row_Size = Fixed_Data_Size + Variable_Data_Size + Null_Bitmap + 4(4是指行标题开销)

开销定义:

Fixed_Data_Size = 所有固定长度列的总字节大小

Variable_Data_Size = 2 + (Num_Variable_Cols x 2) + Max_Var_Size

---通过调节Max_Var_Size来满足最大存储空间

Null_Bitmap = 2 + ((Num_Cols + 7) / 8)(要抛弃余数哦

---保留行中称为 Null 位图的部分来管理列的为空性

page=8k=8*1024=8192字节

其中每页可用字节=8192-96=8096

下面我通过创建新表添加数据验证下:

CREATE TABLE [dbo].[PageSize]
(
[a] [int] NULL,--4字节
[b] [nvarchar](3500) NULL,--7000字节哦
[c] CHAR(4)NULL,--2字节
[d] DATETIME NULL,--8字节
[e] MONEY NULL --8字节
) ON [PRIMARY]

--插入数据

insert [PageSize]
values(1,REPLICATE('A',3500),'KING','2016-05-12 10:41:41.843',89.12)
insert [PageSize]
values(2,REPLICATE('B',3500),'KING','',0)
insert [PageSize]
values(3,REPLICATE('D',3500),'KING','2016-05-12 10:41:41.843',89.00)
insert [PageSize]
values(3,REPLICATE('E',3500),'KING','2016-05-12 10:41:41.843',89.1)
insert [PageSize]
values(3,REPLICATE('F',3500),'KING','2016-05-12 10:41:41.843',89.2)

我们算下第一行行长度:

根据以上公式算下哦:

size=4+4+8+8+7004+3+4=7035(鉴证奇迹的时候到了)

请继续往下面看哦!

--查看页信息
dbcc traceon(3604)

--查看库中表的信息

DBCC SHOWCONTIG

DBCC SHOWCONTIG 正在扫描 'PageSize' 表...
表: 'PageSize' (901578250);索引 ID: 0,数据库 ID: 8
已执行 TABLE 级别的扫描。
- 扫描页数................................: 6
- 扫描区数..............................: 3
- 区切换次数..............................: 2
- 每个区的平均页数........................: 2.0
- 扫描密度 [最佳计数:实际计数].......: 33.33% [1:3]
- 区扫描碎片 ..................: 0.00%
- 每页的平均可用字节数.....................: 2231.5
- 平均页密度(满).....................: 72.43%

--查看库中页集合
dbcc extentinfo(TEST,PageSize)

file_id page_id pg_alloc ext_size object_id index_id partition_number partition_id iam_chain_type pfs_bytes
----------- ----------- ----------- ----------- ----------- ----------- ---------------- -------------------- -------------------- ------------------
1 156 1 1 901578250 0 1 72057594039304192 In-row data 0x6300000000000000
1 164 1 1 901578250 0 1 72057594039304192 In-row data 0x6300000000000000
1 165 1 1 901578250 0 1 72057594039304192 In-row data 0x6300000000000000
1 166 1 1 901578250 0 1 72057594039304192 In-row data 0x6300000000000000
1 168 1 1 901578250 0 1 72057594039304192 In-row data 0x6300000000000000
1 169 1 1 901578250 0 1 72057594039304192 In-row data 0x6000000000000000

看到page页号:

找到第一行 page_id 为156

dbcc page(test,1,156,3)

下面我来拷贝出来大家看下:(这里都没有截图啊,不影响看)

下面蓝字体:第一行是m_pageId = (1:156) 没问题吧

你再看下最后一行:Record Size = 7035 实际记录大小哦

m_pageId = (1:156) m_headerVersion = 1 m_type = 1
m_typeFlagBits = 0x0 m_level = 0 m_flagBits = 0x8000
m_objId (AllocUnitId.idObj) = 88 m_indexId (AllocUnitId.idInd) = 256
Metadata: AllocUnitId = 72057594043695104
Metadata: PartitionId = 72057594039304192 Metadata: IndexId = 0
Metadata: ObjectId = 901578250 m_prevPage = (0:0) m_nextPage = (0:0)
pminlen = 28 m_slotCnt = 1 m_freeCnt = 1059
m_freeData = 7131 m_reservedCnt = 0 m_lsn = (492:6024:2)
m_xactReserved = 0 m_xdesId = (0:0) m_ghostRecCnt = 0
m_tornBits = 0 DB Frag ID = 1

Allocation Status

GAM (1:2) = ALLOCATED SGAM (1:3) = ALLOCATED
PFS (1:1) = 0x63 MIXED_EXT ALLOCATED 95_PCT_FULL DIFF (1:6) = CHANGED
ML (1:7) = NOT MIN_LOGGED

Slot 0 Offset 0x60 Length 7035

Record Type = PRIMARY_RECORD Record Attributes = NULL_BITMAP VARIABLE_COLUMNS
Record Size = 7035

 再来看下dbcc page(test,1,156,3)这个命令分析吧!

PAGE: (1:156) --数据页编号

BUFFER:

BUF @0x00000003FB178AC0 -- 内存中页号

bpage = 0x00000003EFB32000  物理页面   bhash = 0x0000000000000000 bpageno = (1:156) --对应物理文件的页面号
bdbid = 8 --对应的数据库ID  breferences = 0 bcputicks = 0  
bsampleCount = 0 bUse1 = 63157 bstat = 0x10b
blog = 0x15acc bnext = 0x0000000000000000

PAGE HEADER:

--页头96字节

Page @0x00000003EFB32000

m_pageId = (1:156)  --页号  m_headerVersion = 1 m_type = 1 --数据页类型,1:堆表和聚集索引的叶子节点数据
m_typeFlagBits = 0x0 m_level = 0 m_flagBits = 0x8000
m_objId (AllocUnitId.idObj) = 88 表id    m_indexId (AllocUnitId.idInd) = 256
Metadata: AllocUnitId = 72057594043695104
Metadata: PartitionId = 72057594039304192 Metadata: IndexId = 0
Metadata: ObjectId = 901578250 m_prevPage = (0:0) m_nextPage = (0:0)
pminlen = 28 m_slotCnt = 1 --当页行数                       m_freeCnt = 1059--这里剩余空间哦
m_freeData = 7131--这是7035+表头96哦  也是下次插入数据的起始位置                 m_reservedCnt = 0 m_lsn = (492:6024:2)
m_xactReserved = 0 m_xdesId = (0:0) m_ghostRecCnt = 0
m_tornBits = 0 DB Frag ID = 1

这里插一句 大家可能看到了7131+1059=8290?? --实际还要加+行偏移指针数组

因此 7131+1059+2=8292

Allocation Status

GAM (1:2) = ALLOCATED SGAM (1:3) = ALLOCATED
PFS (1:1) = 0x63 MIXED_EXT ALLOCATED 95_PCT_FULL DIFF (1:6) = CHANGED
ML (1:7) = NOT MIN_LOGGED

Slot 0 Offset 0x60 Length

Record Type = PRIMARY_RECORD Record Attributes = NULL_BITMAP VARIABLE_COLUMNS
Record Size = 7035
Memory Dump @0x0000000012E1A060

DBCC page 数据页 堆 底层数据分布大小计算的更多相关文章

  1. (4.4)dbcc checkdb 数据页修复

    转自:http://blog.51cto.com/lzf328/955852 三篇 一.创建错误数据库 以前看Pual写过很多数据恢复的文章,他很多的测试都是自己创建的Corrupt数据库,其实我们自 ...

  2. 利用DBCC PAGE查看SQL Server中的表和索引数据

    16:08 2013-01-06 参考http://doc.chinaunix.net/sqlserver/200810/206034.shtmlDBCC PAGE|IND 参数 DBCC PAGE ...

  3. 数据页结构 .InnoDb行格式、以及索引底层原理分析

    局部性原理 局部性原理是指CPU访问存储器时,无论是存取指令还是存取数据,所访问的存储单元都趋于聚集在一个较小的连续区域中. 首先要明白局部性原理能解决的是什么问题,也就是主存容量远远比缓存大, CP ...

  4. 通过dbcc page来查看表中的数据

    --1.先建表 CREATE TABLE test(idd INT NOT NULL,name VARCHAR(10) NULL) INSERT INTO TEST SELECT 1,'abcdefg ...

  5. 【生产问题】-dbcc checkdb报错-数据页故障

    更多操作参考:https://www.cnblogs.com/gered/p/9435282.html [生产问题]-dbcc checkdb报错-数据页故障 数据页故障,索引页故障 use db_t ...

  6. 通过DBCC Page查看在SQL Server中哪行数据被锁住了?

    原文:通过DBCC Page查看在SQL Server中哪行数据被锁住了? 如何查看被锁的是哪行数据?通过dbcc page可以. 要想明白这个问题: 首先,需要模拟阻塞问题,这里直接模拟了阻塞问题的 ...

  7. SQL Server 存储(1/8):理解数据页结构

    我们都很清楚SQL Server用8KB 的页来存储数据,并且在SQL Server里磁盘 I/O 操作在页级执行.也就是说,SQL Server 读取或写入所有数据页.页有不同的类型,像数据页,GA ...

  8. SQL Server :理解数据页结构

    原文:SQL Server :理解数据页结构 我们都很清楚SQL Server用8KB 的页来存储数据,并且在SQL Server里磁盘 I/O 操作在页级执行.也就是说,SQL Server 读取或 ...

  9. SQL SERVER大话存储结构(1)_数据页类型及页面指令分析

                如果转载,请注明博文来源: www.cnblogs.com/xinysu/   ,版权归 博客园 苏家小萝卜 所有.望各位支持!          SQLServer的数据页大 ...

随机推荐

  1. Cs Round#54 D Spanning Trees

    题意:构造一张N个结点无重边.无自环的无向图.使得其最小生成树和最大生成树共享K条边. 样例一很具有启发性: 当K!=0时,我们可以先构造出一条链,链的长度为n-k的链,作为最小生成树的一部分,之后由 ...

  2. 【NOIP2012提高组】同余方程

    https://www.luogu.org/problem/show?pid=1082 方程可化为ax+by=1. 用扩展欧几里得算法得到ax'+by'=gcd(a,b)的一组解后,可得x=x'/gc ...

  3. 腾讯Web工程师的前端书单

    2014年一月以来,自己接触web前端开发已经两年多了,记录一下自己前端学习路上看过的,以及道听途说的一些书,基本上按照由浅入深来介绍. JavaScript 入门 <JavaScript权威指 ...

  4. Asynchronous MQTT client library for C (MQTT异步客户端C语言库-paho)

    原文:http://www.eclipse.org/paho/files/mqttdoc/MQTTAsync/html/index.html MQTT异步客户端C语言库   用于C的异步 MQTT 客 ...

  5. MyBatis学习总结——实现关联表查询(转)

    原文链接:孤傲苍狼 一.一对一关联 1.1.提出需求 根据班级id查询班级信息(带老师的信息) 1.2.创建表和数据 创建一张教师表和班级表,这里我们假设一个老师只负责教一个班,那么老师和班级之间的关 ...

  6. idea 配置热部署

    1. 2.

  7. 此地址使用了一个通常用于网络浏览以外目的的端口。出于安全原因,Firefox 取消了该请求。

    火狐无法访问本机IIS部署的网站,弹出:此地址使用了一个通常用于网络浏览以外目的的端口.出于安全原因,Firefox 取消了该请求 的解决办法 关于火狐浏览器访问本机IIS部署的网站弹出"此 ...

  8. .Net版InfluxDB客户端使用时的一些坑

    1.如果应用程序是WebAPi,则需要使用同步版的InfluDB客户端 2.如果应用程序是Winform或Console程序或Windows服务,则使用同步或异步版客户端都可以,建议用异步版 3.如果 ...

  9. ajaxFileUpload上传文件简单示例

    写在前面: 上传文件的方式有很多,最近在做项目的时候,一开始也试用了利用jquery的插件ajaxFileUpload来上传大文件,下面,用一个上传文件的简单例子,记录下,学习的过程~~~ 还是老样子 ...

  10. EntityFramework Core数据查询

    前言 本节我们再来讲讲EF Core,本节算是回归基础吧,当前项目EF Core还是处于1.1版本中,后续等待.net core等版本稳定了全部会更新到2.0版本中,到时再来更新相关文章分享给大家. ...