SQL Server查看数据库中每张表的数据量和总数据量

查询将返回每个表的名称和表中的数据行数(RowCounts),并按数据量从大到小排序

复制代码
-- 查询数据库中每张表的行数(数据量)
SELECT 
    t.name AS TableName,  -- 表的名称
    SUM(p.rows) AS RowCounts  -- 表中所有分区的行数之和,即该表的总行数
FROM 
    sys.tables t  -- 视图 sys.tables 存储数据库中的所有表
JOIN      
    sys.indexes i ON t.object_id = i.object_id  -- 视图 sys.indexes 存储每个表的索引信息,连接条件为表的对象 ID
JOIN 
    sys.partitions p ON i.object_id = p.object_id AND i.index_id = p.index_id  -- 视图 sys.partitions 存储每个表和索引分区的信息,连接条件为索引的对象 ID 和分区 ID
WHERE 
    t.is_ms_shipped = 0  -- 排除系统表,确保只查询用户表
    AND i.type <= 1  -- 只考虑堆(没有聚集索引的表)和聚集索引(类型 0 或 1),跳过非聚集索引
GROUP BY 
    t.name  -- 按表名分组,计算每张表的行数
ORDER BY 
    RowCounts DESC;  -- 按行数降序排列,最先显示数据量最大的表
说明:
  1. sys.tables : 这个视图包含了当前数据库中所有的表的信息。它有一个 object_id 列,唯一标识每个表。
  2. sys.indexes : 这个视图存储了与每个表相关的索引信息。每个表至少会有一个默认的聚集索引(如果没有聚集索引,则为堆表)。这里通过 i.type <= 1 来过滤:
    • type = 0 代表聚集索引(clustered index)。
    • type = 1 代表堆表(没有聚集索引的表)。
    • type > 1 代表非聚集索引,不计算在内。
  3. sys.partitions: 这个视图包含了与表的每个分区相关的数据,包括每个分区的行数。每个表可能会有多个分区,特别是在大表中,所以需要按分区聚合行数。
  4. t.is_ms_shipped = 0 : 这确保查询只包含用户创建的表,排除系统表。系统表的 is_ms_shipped 值为 1。
  5. GROUP BY t.name: 根据表的名称对数据进行分组,以便能够计算每个表的行数。
  6. ORDER BY RowCounts DESC: 按照每个表的行数从大到小排序,帮助我们快速识别数据量最大的表。
获取总数据量:

如果您希望查看数据库中所有表的总数据量,可以使用以下查询:

复制代码
-- 查询数据库中所有表的总行数
SELECT 
    'Total' AS TableName,  -- 返回固定的字符串 'Total' 来标识总行数
    SUM(p.rows) AS TotalRowCounts  -- 汇总所有表的行数
FROM 
    sys.tables t  -- 获取所有用户表
JOIN      
    sys.indexes i ON t.object_id = i.object_id  -- 连接索引视图
JOIN 
    sys.partitions p ON i.object_id = p.object_id AND i.index_id = p.index_id  -- 连接分区视图
WHERE 
    t.is_ms_shipped = 0  -- 排除系统表
    AND i.type <= 1;  -- 只计算堆表和聚集索引
结果:
  1. 每张表的行数:返回一个表格,显示每张表的名称和对应的行数(数据量)。
  2. 总行数:单独返回一个值,表示所有表的总行数。

这些查询可以帮助您快速评估数据库的大小和表的分布情况。

相关推荐
马尔代夫哈哈哈1 天前
Spring IoC&DI
数据库·sql
液态不合群1 天前
[特殊字符] MySQL 覆盖索引详解
数据库·mysql
计算机毕设VX:Fegn08951 天前
计算机毕业设计|基于springboot + vue蛋糕店管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
瀚高PG实验室1 天前
PostgreSQL到HighgoDB数据迁移
数据库·postgresql·瀚高数据库
打码人的日常分享1 天前
智能制造数字化工厂解决方案
数据库·安全·web安全·云计算·制造
三水不滴1 天前
Redis 过期删除与内存淘汰机制
数据库·经验分享·redis·笔记·后端·缓存
-孤存-1 天前
MyBatis数据库配置与SQL操作全解析
数据库·mybatis
2301_822366351 天前
使用Scikit-learn构建你的第一个机器学习模型
jvm·数据库·python
wangqiaowq1 天前
MSSQLSERVER 和 SQLEXPRESS 是 SQL Server 中两种不同类型的实例名称
sql
万邦科技Lafite1 天前
一键获取京东商品评论信息,item_reviewAPI接口指南
java·服务器·数据库·开放api·淘宝开放平台·京东开放平台