在以前写过一篇博客"关系数据库如何快速查询表的记录数",里面介绍了使用sp_spaceused查看表的记录数是否正确的问题,具体以下:html
关于问题3:有多个索引的表,是否记录数会存在不一致的状况?
答案:我的测试以及统计来看,暂时发现多个索引的状况下,sys.partitions中的rows记录数都是一致的。暂时没有发现不一致的状况,固然也不排除有特殊状况。
关于问题5: 分区表的状况又是怎么样?
答案:分区表和普通表没有任何区别。
关于问题6:对象目录视图sys.partitions与sp_spaceused获取的表记录函数是否准确?
答案:对象目录视图sys.partitions与sp_spaceused获取的表记录数是准确的。
可是,今天遇到一个问题,直接推翻了以前博客里面下的这个结论。以下截图所示,发现不一样的索引的记录数不同。因此问题3,应该这样回答:数据库
大部分状况下,sys.partitions中的rows记录数都是一致的。可是也有发现不一样索引的rows不一致的状况app
另外,也发现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.partitions与sp_spaceused获取的表记录函数是否准确?spa
答案:对象目录视图sys.partitions与sp_spaceused获取的表记录数是准确的。code
正确答案:对象目录视图sys.partitions与sp_spaceused获取的表记录数是大部分是准确的。可是也存在记录数不许确的状况。只是目前不清楚在什么场景下,会出现不许确的状况。orm