首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >逻辑读取和LOB逻辑读取

逻辑读取和LOB逻辑读取
EN

Database Administration用户
提问于 2022-08-10 10:18:58
回答 2查看 638关注 0票数 3

我有一个用文本字段扫描整个表的查询应用程序。

该查询正在执行以下多项操作:

扫描计数1,逻辑读取170586,物理读取3,预读读取174716,lob逻辑读取7902578,lob物理读取8743,lob预读读取0。

具有lob逻辑读取的查询计划

如果从select中删除文本字段,则读取如下:

扫描计数1,逻辑读取170588,物理读取0,预读0,lob逻辑读取0,lob物理读取0,lob预读读取0.

没有lob逻辑读取的查询计划

我不明白的是lob是如何读取的:

但是整个数据库只有7GB!

我可能遗漏了一些关于逻辑读取和lob逻辑读取的内容。

lob逻辑读取的数量实际上代表什么?

EN

回答 2

Database Administration用户

回答已采纳

发布于 2022-08-17 07:40:07

我想我终于明白了。SET STATISTICS IO ON显示8.073.164 lob逻辑读,这正是记录总数* 2。

这是因为LOB数据存储在B-树结构中,就像普通页面一样!因此,对于每一行,您需要执行两个额外的逻辑读取:一个用于根页,另一个用于数据本身。

这在我的具体情况下是这样的,因为表中最大的文本只有24个字节。

来源

票数 0
EN

Database Administration用户

发布于 2022-08-10 12:16:05

这是我的理论,

这些是逻辑读取,而不是物理读取。假设有两行,其中这些行的LOB数据位于同一个页面上(是的,对于LOB数据,页面可以跨行共享)。

也许每个读取只读取100个字节。每次读取仍然是一个逻辑读取。

此外,您还会说这些是文本数据类型,默认情况是没有LOB数据行。如果类型是var二进制(Max),那么默认情况是将LOB数据排在行中(只要它适合页面)。这会产生很大的影响,什么是最好的取决于您是否经常需要LOB数据。您可以使用sp_tableoption重新配置(这两种类型)。

票数 5
EN
页面原文内容由Database Administration提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://dba.stackexchange.com/questions/315456

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档