SQL SERVER数据存储的形式


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

1

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

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

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

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

2

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

SQL SERVER查询语句执行的顺序


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

3

图有些粗糙。

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

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

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

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

4

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

6

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

7

更多相关文章

  1. Android(安卓)的 supportdesign
  2. Android(安卓)MVP Demo
  3. Android(安卓)P Android.dp添加逻辑判断
  4. Android(安卓)UI系列:关于按钮点击事件
  5. [置顶] Android4.2.2自增物理按键(frameworks)
  6. Android短彩信源码解析-短信发送流程(二)
  7. Android输入系统与Qwerty物理键盘的支持
  8. Android(安卓)模拟物理按键
  9. android 物理按键

随机推荐

  1. 现代 PHP 新特性 —— 闭包
  2. Mysql PHP生成的表:不能使用表
  3. PHP如何检查MySQLi查询是否需要关闭?
  4. 几个有用的php字符串过滤,转换函数代码
  5. 使用/发送POST数据时的libcurl C问题(不
  6. 在自建域名下调试php
  7. 高效的敏感词过滤方法(PHP)
  8. Symfony:我可以从Type / Form返回null吗?
  9. PHP - 将字符串转换为键值数组
  10. ajax在php页面上获得一个值的结果