理解SQL SERVER中的逻辑读,预读和物理读

来源:asp之家 时间:2012-01-05 19:32:29 

SQL SERVER数据存储的形式


在谈到几种不同的读取方式之前,首先要理解SQL SERVER数据存储的方式.SQL SERVER存储的最小单位为页(Page).每一页大小为8k,SQL SERVER对于页的读取是原子性,要么读完一页,要么完全不读,不会有中间状态。而页之间的数据组织结构为B树(请参考我之前的博文).所以SQL SERVER对于逻辑读,预读,和物理读的单位是页.

SQL SERVER一页的总大小为:8K

但是这一页存储的数据会是:8K=8192字节-96字节(页头)-36字节(行偏移)=8060字节

所以每一页用于存储的实际大小为8060字节.

比如上面AdventureWorks中的Person.Address表,通过SSMS看到这个表的数据空间为:

我们可以通过公式大概推算出占用了多少页:2.250*1024*1024/8060(每页的数据容量)≈293 - 表中非数据占用的空间≈290(上图中的逻辑读取数)


SQL SERVER查询语句执行的顺序


SQL SERVER查询执行的步骤如果从微观来看,那将会非常多。这里为了讲述逻辑读等概念,我从比较高的抽象层次来看:

图有些粗糙。

下面我解释一下图。当遇到一个查询语句时,SQL SERVER会走第一步,分别为生成执行计划(占用CPU和内存资源),同步的用估计的数据去磁盘中取得需要取的数据(占用IO资源,这就是预读),注意,两个第一步是并行的,SQL SERVER通过这种方式来提高查询性能.

然后查询计划生成好了以后去缓存读取数据.当发现缓存缺少所需要的数据后让缓存再次去读硬盘(物理读)

最后从缓存中取出所有数据(逻辑读)。

下面我再通过一个简单的例子说明一下:

这个估计的页数数据可以通过这个DMV看到:





当我们第一次查询完成后,再次进行查询时,所有请求的数据这时已经在缓存中,SQL SERVER这时只要对缓存进行读取就行了,也就是只用进行逻辑读:

标签:逻辑读,预读,物理读
0
投稿

猜你喜欢

  • asp函数判断服务器是否安装了某种组件

    2008-10-11 14:45:00
  • 如何提升JavaScript的运行速度(DOM篇)

    2010-05-17 13:32:00
  • IE6绝对定位的bug及其解决办法

    2011-03-30 12:31:00
  • ASP 使用jqGrid实现读写删的代码(json)

    2010-03-07 17:26:00
  • 移动网站开发:标记语言

    2010-06-08 13:42:00
  • SQL Server 2000 SP4补丁打不上的解决办法

    2010-03-08 13:13:00
  • text-indent 隐藏文字时出现的 outline问题

    2007-12-02 17:31:00
  • 管理员必读10个重要MySQL客户启动选项

    2008-06-07 16:57:00
  • ASP常见数学函数 Abs Atn Cos 等详解

    2008-05-28 12:33:00
  • ASP 支持中文的len(),left(),right()的函数代码

    2011-03-03 10:59:00
  • 初衷和结果

    2009-02-23 12:52:00
  • iframe高度自适应,兼容IE,FF

    2008-06-18 12:15:00
  • asp中去除html中style,javascript,css代码

    2011-02-16 11:18:00
  • 三大措施设置数据库安全 保障网站安全运营

    2008-11-28 14:41:00
  • asp程序运行速度测试

    2008-02-11 19:11:00
  • 如何在ADO服务器端利用好缓存技术?

    2010-06-17 12:49:00
  • on error goto (Vbscript)和try catch

    2008-08-04 13:22:00
  • CSS实现完美垂直居中

    2007-09-22 09:29:00
  • ASP 调用带参数输出的COM接口

    2011-03-17 10:59:00
  • 很有意思的SQL多行数据拼接

    2011-11-03 17:08:29
  • asp之家 网络编程 m.aspxhome.com