博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQL Server使用sp_spaceused查看表记录存在不准确的情况
阅读量:6039 次
发布时间:2019-06-20

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

SQL Server使用sp_spaceused查看表记录存在不准确的情况

在之前写过一篇博客"关系数据库如何快速查询表的记录数",里面介绍了使用sp_spaceused查看表的记录数是否正确的问题,具体如下:

关于问题3:有多个索引的表,是否记录数会存在不一致的情况?

答案:个人测试以及统计来看,暂时发现多个索引的情况下,sys.partitions中的rows记录数都是一致的。暂时没有发现不一致的情况,当然也不排除有特殊情况。

关于问题5: 分区表的情况又是怎么样?

答案:分区表和普通表没有任何区别。

关于问题6:对象目录视图sys.partitions与sp_spaceused获取的表记录函数是否准确?

答案:对象目录视图sys.partitions与sp_spaceused获取的表记录数是准确的。

但是,今天遇到一个问题,直接推翻了之前博客里面下的这个结论。如下截图所示,发现不同的索引的记录数不一样。所以问题3,应该这样回答:

大部分情况下,sys.partitions中的rows记录数都是一致的。但是也有发现不同索引的rows不一致的情况

另外,也发现sp_spaceused 中返回的记录数跟SELECT COUNT(*) 不一致。但是从碎片,统计信息等各个方面都分析了一下,实在没有搞清楚什么原因会导致这种情况出现。在数据库找了一下,发现这样的情况非常少,但是确实也是存在的。特此记录一下

sp_spaceused 'dbo.spcecial_table';

SELECT partition_id, object_id, index_id,row_count

FROM sys.dm_db_partition_stats
WHERE object_id= OBJECT_ID('dbo.spcecial_table')

SELECT object_id, index_id, rows FROM sys.partitions

WHERE object_id= OBJECT_ID('dbo.spcecial_table')

SELECT object_id, index_id, rows FROM sys.partitions

WHERE object_id= OBJECT_ID('spcecial_table');

SELECT COUNT(*) FROM spcecial_table

如下截图所示,sp_spaceused 获取的记录数为8718528, 但是SELECT COUNT(*)为8735537。

clip_image002_thumb

关于问题6:对象目录视图sys.partitions与sp_spaceused获取的表记录函数是否准确?

答案:对象目录视图sys.partitions与sp_spaceused获取的表记录数是准确的。

正确答案:对象目录视图sys.partitions与sp_spaceused获取的表记录数是大部分是准确的。但是也存在记录数不准确的情况。只是目前不清楚在什么场景下,会出现不准确的情况。

作者:潇湘隐者

出处:

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

你可能感兴趣的文章
wps怎么转图片?
查看>>
多人聊天
查看>>
科略教育—企业管理运营八大基本法
查看>>
I/O多路转接之select
查看>>
IPScan的作用
查看>>
我的友情链接
查看>>
mysql主从复制
查看>>
etc目录下配置文件详解
查看>>
配置 yum 源的两种方法
查看>>
A10 负载均衡模拟器下载安装及license免费激活详细介绍
查看>>
SQL Server数据库的存储过程中定义的临时表,真的有必要显式删除(drop table #tableName)吗?...
查看>>
双向链表的几种实现
查看>>
我的友情链接
查看>>
Ubuntu快捷键
查看>>
RGBA是什么
查看>>
华三云ONEstor存储测试
查看>>
centos用lastb命令看失败登录记录
查看>>
*** 2003
查看>>
Microsoft Deployment Toolkit 2010 (MDT)下载地址
查看>>
sort与uniq
查看>>