我有一个用文本字段扫描整个表的查询应用程序。
该查询正在执行以下多项操作:
扫描计数1,逻辑读取170586,物理读取3,预读读取174716,lob逻辑读取7902578,lob物理读取8743,lob预读读取0。
如果从select中删除文本字段,则读取如下:
扫描计数1,逻辑读取170588,物理读取0,预读0,lob逻辑读取0,lob物理读取0,lob预读读取0.
我不明白的是lob是如何读取的:
但是整个数据库只有7GB!
我可能遗漏了一些关于逻辑读取和lob逻辑读取的内容。
lob逻辑读取的数量实际上代表什么?
发布于 2022-08-17 07:40:07
我想我终于明白了。SET STATISTICS IO ON显示8.073.164 lob逻辑读,这正是记录总数* 2。
这是因为LOB数据存储在B-树结构中,就像普通页面一样!因此,对于每一行,您需要执行两个额外的逻辑读取:一个用于根页,另一个用于数据本身。
这在我的具体情况下是这样的,因为表中最大的文本只有24个字节。
发布于 2022-08-10 12:16:05
这是我的理论,
这些是逻辑读取,而不是物理读取。假设有两行,其中这些行的LOB数据位于同一个页面上(是的,对于LOB数据,页面可以跨行共享)。
也许每个读取只读取100个字节。每次读取仍然是一个逻辑读取。
此外,您还会说这些是文本数据类型,默认情况是没有LOB数据行。如果类型是var二进制(Max),那么默认情况是将LOB数据排在行中(只要它适合页面)。这会产生很大的影响,什么是最好的取决于您是否经常需要LOB数据。您可以使用sp_tableoption重新配置(这两种类型)。
https://dba.stackexchange.com/questions/315456
复制相似问题