承接国内外服务器租用托管、定制开发、网站代运营、网站seo优化托管接单、网站代更新,新老站点皆可!!咨询QQ:3787320601

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

管理员 2023-08-24 08:16:04 互联网圈 0 ℃ 0 评论 7049字 收藏

前言

在之前写过一篇博客”关系数据库怎样快速查询表的记录数“,里面介绍了使用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。

 

关于问题6:对象目录视图sys.partitionssp_spaceused获得的表记录函数会不会准确?

  答案:对象目录视图sys.partitionssp_spaceused获得的表记录数是准确的。

正确答案:对象目录视图sys.partitionssp_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。

 

关于问题6:对象目录视图sys.partitionssp_spaceused获得的表记录函数会不会准确?

  答案:对象目录视图sys.partitionssp_spaceused获得的表记录数是准确的。

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

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或工作具有一定的参考学习价值,谢谢大家对的支持。

文章来源:丸子建站

文章标题:关于SQL Server利用sp_spaceused查看表记录存在不准确的情况

https://www.wanzijz.com/view/74014.html

相关文章

Related articles

X

截屏,微信识别二维码

微信号:weimawl

(点击微信号复制,添加好友)

打开微信