下载安卓APP箭头
箭头给我发消息

客服QQ:3315713922

了解SQL Server利用sp_spaceused如何查看表记录存在不准确的情况

作者:课课家教育     来源: http://www.kokojia.com点击数:694发布时间: 2019-04-17 10:04:27

标签: 数据库系统工程师数据库系统工程师视频数据库工程师

  其实呢,今天为大家介绍一篇比较实用的文章,这篇文章主要关于SQL的内容,简单地来说一下,SQLServer利用sp_spaceused如何查看表记录存在不准确情况的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用SQLServer具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧。期望大家能够学习好这些内容。

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

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

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

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

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

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

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

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

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

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

  sp_spaceused'dbo.spcecial_table';

  SELECTpartition_id,object_id,index_id,row_count

  FROMsys.dm_db_partition_stats

  WHEREobject_id=OBJECT_ID('dbo.spcecial_table')

  SELECTobject_id,index_id,rowsFROMsys.partitions

  WHEREobject_id=OBJECT_ID('dbo.spcecial_table')

  SELECTobject_id,index_id,rowsFROMsys.partitions

  WHEREobject_id=OBJECT_ID('spcecial_table');

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

了解SQL Server利用sp_spaceused如何查看表记录存在不准确的情况_数据库_数据库管理_SQL_课课家

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

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

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

  小编结语:

  其实,针对于这些内容,大家是否都掌握了呢?因为知识是需要积累的,比如对象目录视图sys.partitions与sp_spaceused获取的表记录函数是否准确?大家又是否知道答案呢?

赞(26)
踩(0)
分享到:
华为认证网络工程师 HCIE直播课视频教程