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

作者:潇湘隐者 时间:2024-01-20 07:40:10 

前言

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

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

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

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

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

来源:https://www.cnblogs.com/kerrycode/p/10674835.html

标签:sqlserver,sp,spaceused,表记录
0
投稿

猜你喜欢

  • Mysqlslap MySQL压力测试工具 简单教程

    2024-01-15 20:10:10
  • Oracle 随机数

    2024-01-16 10:46:14
  • Python基础之getpass模块详细介绍

    2021-03-06 13:47:13
  • Python HTMLParser模块解析html获取url实例

    2023-08-18 01:09:47
  • 深入了解python的tkinter实现简单登录

    2023-03-25 14:15:27
  • Python编写一个闹钟功能

    2022-02-14 14:03:08
  • javaScript中一些常见的数据类型检查校验

    2023-07-02 05:19:09
  • 名片管理系统python版

    2021-08-06 01:50:15
  • Vue 路由传参加密的示例代码

    2024-05-09 10:50:34
  • 制作主页的独门功夫五十招

    2010-09-05 21:15:00
  • 限制文本框只能输入数字和小数点

    2009-05-29 18:19:00
  • PPOCRLabel标注的txt格式如何转换成labelme能修改的json格式

    2021-08-31 06:01:45
  • 基于Python实现通过微信搜索功能查看谁把你删除了

    2022-07-10 00:19:37
  • 使用phpMyAdmin进行mysql数据库备份和还原的方法

    2008-10-13 20:56:00
  • 深入解析Go语言编程中的递归使用

    2023-10-09 09:24:36
  • 解决Python报错:ValueError:operands could not be broadcast together with shapes

    2021-05-14 12:04:53
  • Python学习之线程池与GIL全局锁详解

    2021-10-09 21:55:18
  • Python selenium页面加载慢超时的解决方案

    2022-10-15 04:37:43
  • asp.net 上传下载输出二进制流实现代码

    2023-06-28 16:06:05
  • CentOS7环境下源码安装MySQL5.7的方法

    2024-01-26 04:38:56
  • asp之家 网络编程 m.aspxhome.com