博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
理解SQL SERVER中的逻辑读,预读和物理读
阅读量:6169 次
发布时间:2019-06-21

本文共 950 字,大约阅读时间需要 3 分钟。

 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这时只要对缓存进行读取就行了,也就是只用进行逻辑读:

====================================分割线================================

最新内容请见作者的GitHub页:http://qaseven.github.io/

转载地址:http://uenba.baihongyu.com/

你可能感兴趣的文章
修改 IntelliJ IDEA 默认配置路径
查看>>
《现在的泪,都是当年脑子进的水》读书笔记
查看>>
IOSday04 UIButton使用
查看>>
铁大好青年内部分组
查看>>
unity3D ——自带寻路Navmesh入门教程(一)(转)
查看>>
判断字符串是否为数字的函数
查看>>
[emuch.net]MatrixComputations(7-12)
查看>>
linux 命令 — 文件相关
查看>>
自己空闲的时候封装一下
查看>>
Datagard產生gap
查看>>
本机web开发环境的搭建--nginx篇
查看>>
rcnn 理解笔记
查看>>
问答项目---登陆验证码点击切换及异步验证验证码
查看>>
plist文件中iphone和ipad的应用图片设置
查看>>
搜集的一些资源网站链接
查看>>
struts2中类型转换器的使用
查看>>
11G Oracle RAC添加新表空间时数据文件误放置到本地文件系统的修正
查看>>
从91移动应用发展趋势报告看国内应用现状
查看>>
【ORACLE技术嘉年华PPT】MySQL压力测试经验
查看>>
Linux下汇编调试器GDB的使用
查看>>