查看SQLSERVER内部数据页面的小插件Internals Viewer

原文:查看SQLSERVER内部数据页面的小插件Internals Viewer

查看SQLSERVER内部数据页面的小插件Internals Viewer

感觉internals viewer这个名字起得很好,内部查看。

这个小工具是我之前看园子里的某大侠转载的文章是看到的

文章地址:
SQL Server2008存储结构之堆表、行溢出

http://www.cnblogs.com/trams/archive/2010/09/11/1823727.html

这几天研究了一下这个小工具,发现挺好用的,对入想深入研究或者刚刚学SQLSERVER但是想对SQL有更深入了解的朋友们特别有用



先给出下载地址,这个是codeplex上的一个项目:

http://internalsviewer.codeplex.com/

我也上传到了自己的网盘,大家也可以到我的网盘下载:http://www.kuaipan.cn/file/id_4401224786924003.htm

 InternalsViewerInstaller.msi 安装就不说了,直接双击安装,安装前最好先关闭SSMS

官方上说:可以用在SQL2005 SQL2008  ,我自己的电脑是SQL2005 Windows7可以使用

 

 

下载安装好之后,再打开SSMS,会看到SSMS的菜单增加了一个

 

 点击Internals Viewer会有两个菜单:display transaction logAllocation Map

不知道为什么display transaction log用不了,本人非常想知道display transaction log是什么功能

只好点击“Allocation Map” ,点击之后会弹出 连接对话框,大家选择验证方式连接就可以了不多说了



打开之后会看到如下图

 上面几个按钮

选择要查看的数据库

PFS:查看数据库的空闲页面情况

buffer pool:看下图

small:调整小方格的大小

key:是否显示数据库的表,如果不点击key下面不会显示表的

File Details:看上面那个图



小方格颜色的含义

点击某个小方格就会显示那个小方格的信息,每个小方格代表一个页面

小方格的颜色是跟下面表格的颜色是一一对应的,表示这些表格数据在数据库中的分布情况

 

鼠标在小方格上移动会看到这个小方格属于哪个表

 鼠标左键单击某个小方格会显示这个页面的信息

如果你想看某个表的数据,你可以点击那个表,然后就会显示出那个表的数据分布情况,你点击某个小方格就可以看到那个表的数据了~



先从数据库的开头几个页面说起吧

 

数据库第1页:file header page

数据库第2页:PFS  (Page Free Space) ,也叫页面自由空间,该页面用来跟踪一个文件中每一个特定页面的利用率情况

数据库第3页:GAM 全局分配映射(Global Allocation Map,GAM)页面  这些页面记录了哪些区已经被分配并用作何种用途

数据库第4页:SGAM 共享全局分配映射(Shared Global Allocation Map,SGAM)页面  这些页面记录了哪些区当前被用作混合类型的区,并且这些区需含有至少一个未使用的页面

第5页没有数据

第6页没有数据

数据库第7页:DCM 差异变更(Differential Changed Map,DCM)页面 他跟踪一个文件中的哪一个区在最新一次完整数据库备份之后被修改过。SQLSERVER
用在增量备份时只对已发生数据变更的分区进行增量备份即可

资料:SQL Server 2008 存储结构之DCM、BCM

数据库第8页:BCM 批量更改映射(Bulk Changed Map)页面,该页面当文件中的一个区在最小量或批量日志操作中被
使用时用到。

数据库第9页:sys.sysqnames 存在于每个数据库中。

4 字节 ID 标记的每个命名空间或限定名均存在对应的一行。

像dbcc checkprimaryfile命令的信息应该就存储于这个页面中

数据库第10页:boot page 数据库根据这个页面的信息来启动的

 



IAM页面

下面那里写错了,应该是堆表才有

 



具体页面信息

 每个小方格代表一个页面,左边这些信息估计是使用了这两条语句:DBCC IND()   DBCC PAGE()

 

 

 下方显示对应的表数据

 

左上角显示了这个页面是数据页还是IAM页



数据行的结构

关于数据行的结构,大家可以看文章最开始给出的

文章地址: SQL Server2008存储结构之堆表、行溢出

http://www.cnblogs.com/trams/archive/2010/09/11/1823727.html

我摘抄一部分

其中状态A为如下说明:
 
  bit0:版本信息,在SQL Server 2005/08总是为0
 
  bit1-3: 0=(primary record);1=(forwarded record);2=(forwarding stud);3=(index record);4=(溢出数据);5=(ghost索引记录);6=(ghost数据记录)
 
  bit4:表示存在NULL位图(在数据行里SQL2005/08总存在NULL位图)
 
  bit5:表示存在变长列
 
  bit6:未启用
 
  bit7:表示存在幽灵记录
 
  本例中30->00110000 它是一个行属性的位图 从高位存到低位(右边第一位是bit0),bit4为1即存在变长列的字段,因为在SQLServer2005/2008中总存在NULL位图,所以bit5也为1。
 
  状态位B在SQLServer2005//2008中未启用,所以为00



IAM页和数据页的差别

堆表只依靠表里的IAM页(索引分配映射页)将堆的页面联系在一起,IAM里记录了页面编号,页面位置

红色的小方格就是记录了sys.syscolpars这张表他的数据页面在数据库中的分布情况



关于这个软件

我点击了一下IAM页面下方的小方格就报错了,然后弹出一个对话框,原来这个软件使用.NET来编写的

我们国人什么时候也能够写一个呢?

 

----------------------------------------------------------------------------------------------------

最后附上各个系统页面的作用和详细介绍地址

PFS页面介绍:  http://dev.21tx.com/2011/11/24/11378.html
DCM BCM页面介绍:  http://tech.it168.com/a2010/0921/1106/000001106857.shtml
GAM SGAM页面介绍:http://www.efficient-it.com.cn/space/78/viewspace/itemid/6756.html

时间: 2024-09-29 07:49:32

查看SQLSERVER内部数据页面的小插件Internals Viewer的相关文章

SQLSERVER的数据页面结构

  SQLSERVER的数据页面结构 在论坛里经常有人问到SQLSERVER是怎麽存放基础表数据的,既然不想查MSDN,本人就在这里说一下吧 每一行数据在数据页面里是怎麽存放的? 结构组成:每个SQLSERVER的数据页面大致分成3个部分:页头,页尾偏移量,数据存储 这3个部分 假设现在有一个表,表的结构是: CREATE TABLE test( a INT, b INT ) 他在1:100这个页面上存储数据(1是数据库的数据文件ID 亦即是FILEID,100 是PAGEID 页面编号). 这

使用Internals Viewer插件查看SQL SERVER内部数据页面

感觉internals viewer这个名字起得很好,内部查看. 这个小工具是我之前看园子里的某大侠转载的文章是看到的 文章地址: SQL Server2008存储结构之堆表.行溢出 http://www.cnblogs.com/trams/archive/2010/09/11/1823727.html 这几天研究了一下这个小工具,发现挺好用的,对入想深入研究或者刚刚学SQLSERVER但是想对SQL有更深入了解的朋友们特别有用 先给出下载地址,这个是codeplex上的一个项目: http:/

解剖SQLSERVER 完结篇 关于Internals Viewer源代码

原文:解剖SQLSERVER 完结篇 关于Internals Viewer源代码 解剖SQLSERVER 完结篇 关于Internals Viewer源代码 大家可能都用过Internals Viewer这个软件 <查看SQLSERVER内部数据页面的小插件Internals Viewer> 但是不知道有多少人看过他的源代码呢? 作者把源代码放在在CodePlex网站上面,但是这个源代码只支持SQL2008及以下,不支持SQL2008R2 后来有人根据原作者的代码改写出了 SQL2008R2版

解剖SQLSERVER 第二篇 对数据页面头进行逆向(译)

原文:解剖SQLSERVER 第二篇 对数据页面头进行逆向(译) 解剖SQLSERVER 第二篇  对数据页面头进行逆向(译) http://improve.dk/reverse-engineering-sql-server-page-headers/ 在开发OrcaMDF 的时候第一个挑战就是解析数据页面头部,我们知道数据页面分两部分,96字节的页面头部和8096字节的数据行 大神 Paul Randal 写了一篇文章很好的描述了页头结构,然而,即使文章描述得很详细,但是我还是找不出任何关于页

静态页面跳转传值小插件

原文:静态页面跳转传值小插件 场景:在注册网站时,需要通过邮箱去验证时需要用到的小插件. test.html: <a href="test1.html?name=caoy&my=wang">静态传值</a> test1.html: <script type="text/javascript" src="getUrlParam.js"></script> <script> UrlP

人生日历小插件,方便大生活

人生日历是一款方便我们生活的多功能日历,除了一些常用的日历功能以外,人生日历的小插件还能给我们的工作生活带来极大的便利,下面就随小编一起体验一番人生日历的小插件是怎样方便我们的大生活的吧. 打开人生日历,我们可以看到人生日历界面的下方有一排应用小插件,喜欢人生日历的朋友应该对这些小插件不陌生吧.我们可以在人生日历中记事,设置亲朋好友的生日提醒,可以查询自己的星座运势,可以预订火车票,还可以随心更换电脑的桌面壁纸,甚至我们还可以在人生日历上快速关机--这些小插件虽然小,却总能在我们需要的时候发挥巨

SQLServer性能数据解析

磁盘相关 ins_dir = MSSQL_DIR + "/ms" + str(port) data_dir = ins_dir + '/data' log_dir = ins_dir + '/log' backup_dir = ins_dir + '/backup' ins_size = func_os.get_dir_size(ins_dir) data_size = func_os.get_dir_size(data_dir) log_size = func_os.get_dir_

SQL SERVER 数据页面头部结构解析

解析数据页面头部结构: if object_id('test') is not null drop table test go create table test( id int,birth datetime,name char(10)) insert into test select 1,'2009-11-27','aaaa' union all select 2,'2009-11-27','aaaa' exec sp_spaceused 'test' 结构: name rows reserv

PS小插件GuideGuide 生成像素级别的辅助线

提高效率的小工具GuideGuide 今天为大家介绍一款非常实用的PS小插件GuideGuide,它提供了一个非常便捷的方式生成像素级别的辅助线(栏,行,中线--) 想像一下在PS里面创建好一组多栏目的辅助线:页面多宽,分2栏目还是3栏,分栏里面又有多少个分栏--数学不好的同学估计手心都开始冒汗了.确实,在PS里面创建网格是个非常痛苦的事情,不少设计同学都是大概估算一下宽高来拉辅助线;或者画一个矢量图形,然后复制移动来分列.如果总的宽度有了变化之后,又将他们整体拉宽来重新分列.没耐心的人估计已经