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

 更新时间:2011年12月27日 00:11:10   作者:  
在我的上一篇关于SQL SERVER索引的博文,有圆友问道关于逻辑读,预读和物理读的概念.我觉的还是写一篇博文能把这个问题解释清楚

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

相关文章

  • SQL学习笔记五去重,给新加字段赋值的方法

    SQL学习笔记五去重,给新加字段赋值的方法

    SQL学习笔记五去重,给新加字段赋值的方法,需要的朋友可以参考下。
    2011-08-08
  • SQL Server2019数据库之简单子查询的具有方法

    SQL Server2019数据库之简单子查询的具有方法

    这篇文章主要介绍了SQL Server2019数据库之简单子查询的具有方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04
  • 向数据库中插入数据并返回当前插入的行数及全局变量@@IDENTITY应用

    向数据库中插入数据并返回当前插入的行数及全局变量@@IDENTITY应用

    向数据库中插入数据并返回当前插入的的行数,这项功能很实用的可以判断是否为批量插入主要是利用全局变量@@IDENTITY实现,感兴趣的朋友可以了解下啊,希望本文对你巩固sql知识很有帮助的
    2013-01-01
  • SQL Server数据库常用语句总结大全

    SQL Server数据库常用语句总结大全

    SQL Server数据库常用的SQL语句有很多,下面这篇文章主要给大家总结介绍了关于SQL Server数据库常用语句的相关资料,文中通过代码介绍的非常详细,对大家的学习或者工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2024-08-08
  • SqlServer 2022通过临时表和游标遍历方式逻辑处理获取目标数据

    SqlServer 2022通过临时表和游标遍历方式逻辑处理获取目标数据

    在SQL的存储过程,函数中,经常需要使用遍历(遍历table),其中游标、临时表等遍历方法很常用,本文就来介绍一下SqlServer 2022通过临时表和游标遍历方式逻辑处理获取目标数据,感兴趣的可以了解一下
    2024-04-04
  • sql基本函数大全

    sql基本函数大全

    sql基本函数大全...
    2007-03-03
  • Sql Server 2012 分页方法分析(offset and fetch)

    Sql Server 2012 分页方法分析(offset and fetch)

    最近在分析 Sql Server 2012 中 offset and fetch 的新特性,发现 offset and fetch 无论语法的简洁还是功能的强大,都是相当相当不错的
    2012-08-08
  • Navicat 连接SQLServer数据库(图文步骤)

    Navicat 连接SQLServer数据库(图文步骤)

    这篇文章主要介绍了Navicat 连接SQLServer数据库(图文步骤),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04
  • sql coalesce函数的具体使用

    sql coalesce函数的具体使用

    这篇文章主要介绍了sql coalesce函数的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-10-10
  • 详解将DataGrip连接到MS SQL Server的方法

    详解将DataGrip连接到MS SQL Server的方法

    这篇文章主要介绍了详解将DataGrip连接到MS SQL Server的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-11-11

最新评论