如何获取SQL Server数据库里表的占用容量大小(转)

2024-03-04 06:18

本文主要是介绍如何获取SQL Server数据库里表的占用容量大小(转),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

其实只要使用系统内置的存储过程sp_spaceused就可以得到表的相关信息

如:sp_spaceused 'tablename'

以下是为了方便写的一个存储过程,目的是把当前的所有表的相关信息全部都保存在一个指定的表里面

CREATE   PROCEDURE  get_tableinfo  AS

if   not   exists  ( select   *   from  dbo.sysobjects  where  id  =   object_id (N ' [dbo].[tablespaceinfo] ' and   OBJECTPROPERTY (id, N ' IsUserTable ' =   1 )
create   table   tablespaceinfo                          -- 创建结果存储表
              (nameinfo  varchar ( 50 ) , 
               rowsinfo 
int  , reserved  varchar ( 20 ) , 
               datainfo 
varchar ( 20 )  , 
               index_size 
varchar ( 20 ) , 
               unused 
varchar ( 20 ) )


delete   from  tablespaceinfo  -- 清空数据表

declare   @tablename   varchar ( 255 )   -- 表名称

declare   @cmdsql   varchar ( 500 )

DECLARE  Info_cursor  CURSOR   FOR  
select  o.name  
from  dbo.sysobjects o  where   OBJECTPROPERTY (o.id, N ' IsTable ' =   1  
     
and  o.name  not   like  N ' #%% '    order   by  o.name

OPEN  Info_cursor

FETCH   NEXT   FROM  Info_cursor 
INTO   @tablename  

WHILE   @@FETCH_STATUS   =   0
BEGIN

  
if   exists  ( select   *   from  dbo.sysobjects  where  id  =   object_id ( @tablename and   OBJECTPROPERTY (id, N ' IsUserTable ' =   1 )
  
execute  sp_executesql 
         N
' insert into tablespaceinfo  exec sp_spaceused @tbname ' ,
          N
' @tbname varchar(255) ' ,
          
@tbname   =   @tablename

  
FETCH   NEXT   FROM  Info_cursor 
  
INTO   @tablename  
END

CLOSE  Info_cursor
DEALLOCATE  Info_cursor
GO
select *
from tablespaceinfo 
order by cast(left(ltrim(rtrim(reserved)) , len(ltrim(rtrim(reserved)))-2) as int) desc

这篇关于如何获取SQL Server数据库里表的占用容量大小(转)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/772250

相关文章

详解MySQL中DISTINCT去重的核心注意事项

《详解MySQL中DISTINCT去重的核心注意事项》为了实现查询不重复的数据,MySQL提供了DISTINCT关键字,它的主要作用就是对数据表中一个或多个字段重复的数据进行过滤,只返回其中的一条数据... 目录DISTINCT 六大注意事项1. 作用范围:所有 SELECT 字段2. NULL 值的特殊处

PostgreSQL数据库密码被遗忘时的操作步骤

《PostgreSQL数据库密码被遗忘时的操作步骤》密码遗忘是常见的用户问题,因此提供一种安全的遗忘密码找回机制是十分必要的,:本文主要介绍PostgreSQL数据库密码被遗忘时的操作步骤的相关资... 目录前言一、背景知识二、Windows环境下的解决步骤1. 找到PostgreSQL安装目录2. 修改p

MySQL 用户创建与授权最佳实践

《MySQL用户创建与授权最佳实践》在MySQL中,用户管理和权限控制是数据库安全的重要组成部分,下面详细介绍如何在MySQL中创建用户并授予适当的权限,感兴趣的朋友跟随小编一起看看吧... 目录mysql 用户创建与授权详解一、MySQL用户管理基础1. 用户账户组成2. 查看现有用户二、创建用户1. 基

MySQL 打开binlog日志的方法及注意事项

《MySQL打开binlog日志的方法及注意事项》本文给大家介绍MySQL打开binlog日志的方法及注意事项,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录一、默认状态二、如何检查 binlog 状态三、如何开启 binlog3.1 临时开启(重启后失效)

SQL BETWEEN 语句的基本用法详解

《SQLBETWEEN语句的基本用法详解》SQLBETWEEN语句是一个用于在SQL查询中指定查询条件的重要工具,它允许用户指定一个范围,用于筛选符合特定条件的记录,本文将详细介绍BETWEEN语... 目录概述BETWEEN 语句的基本用法BETWEEN 语句的示例示例 1:查询年龄在 20 到 30 岁

MySQL DQL从入门到精通

《MySQLDQL从入门到精通》通过DQL,我们可以从数据库中检索出所需的数据,进行各种复杂的数据分析和处理,本文将深入探讨MySQLDQL的各个方面,帮助你全面掌握这一重要技能,感兴趣的朋友跟随小... 目录一、DQL 基础:SELECT 语句入门二、数据过滤:WHERE 子句的使用三、结果排序:ORDE

SpringMVC高效获取JavaBean对象指南

《SpringMVC高效获取JavaBean对象指南》SpringMVC通过数据绑定自动将请求参数映射到JavaBean,支持表单、URL及JSON数据,需用@ModelAttribute、@Requ... 目录Spring MVC 获取 JavaBean 对象指南核心机制:数据绑定实现步骤1. 定义 Ja

MySQL MCP 服务器安装配置最佳实践

《MySQLMCP服务器安装配置最佳实践》本文介绍MySQLMCP服务器的安装配置方法,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下... 目录mysql MCP 服务器安装配置指南简介功能特点安装方法数据库配置使用MCP Inspector进行调试开发指

mysql中insert into的基本用法和一些示例

《mysql中insertinto的基本用法和一些示例》INSERTINTO用于向MySQL表插入新行,支持单行/多行及部分列插入,下面给大家介绍mysql中insertinto的基本用法和一些示例... 目录基本语法插入单行数据插入多行数据插入部分列的数据插入默认值注意事项在mysql中,INSERT I

一文详解MySQL如何设置自动备份任务

《一文详解MySQL如何设置自动备份任务》设置自动备份任务可以确保你的数据库定期备份,防止数据丢失,下面我们就来详细介绍一下如何使用Bash脚本和Cron任务在Linux系统上设置MySQL数据库的自... 目录1. 编写备份脚本1.1 创建并编辑备份脚本1.2 给予脚本执行权限2. 设置 Cron 任务2