经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MS SQL Server » 查看文章
SQL Server使用sp_spaceused查看表记录存在不准确的情况
来源:cnblogs  作者:潇湘隐者  时间:2019/4/9 9:57:59  对本文有异议

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

 

 

  1.  
  1. 关于问题3:有多个索引的表,是否记录数会存在不一致的情况?
  1.  
  1.    答案:个人测试以及统计来看,暂时发现多个索引的情况下,sys.partitions中的rows记录数都是一致的。暂时没有发现不一致的情况,当然也不排除有特殊情况。
  1.  
  1. 关于问题5: 分区表的情况又是怎么样?
  1.  
  1.    答案:分区表和普通表没有任何区别。
  1.  
  1. 关于问题6:对象目录视图sys.partitionssp_spaceused获取的表记录函数是否准确?
  1.  
  1.    答案:对象目录视图sys.partitionssp_spaceused获取的表记录数是准确的。

 

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

 

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

 

 

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

 

 

  1. sp_spaceused 'dbo.spcecial_table';
  1.  
  1. SELECT partition_id, object_id, index_id,row_count
  1. FROM sys.dm_db_partition_stats
  1. WHERE object_id= OBJECT_ID('dbo.spcecial_table')
  1.  
  1.  
  1.  
  1.  
  1. SELECT object_id, index_id, rows FROM sys.partitions
  1. WHERE object_id= OBJECT_ID('dbo.spcecial_table')
  1.  
  1.  
  1.  
  1. SELECT object_id, index_id, rows FROM sys.partitions
  1. WHERE object_id= OBJECT_ID('spcecial_table');
  1.  
  1.  
  1. 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://www.cnblogs.com/kerrycode/p/10674835.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号