SQL SERVER统计服务器所有的数据库(数据库文件)、表(表行数)、字段(各字段)等详细信息

本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
云数据库 RDS SQL Server,基础系列 2核4GB
简介: 原文: SQL SERVER统计服务器所有的数据库(数据库文件)、表(表行数)、字段(各字段)等详细信息 USE STAT GO SET NOCOUNT ON IF EXISTS(SELECT 1 FROM SYS.
原文: SQL SERVER统计服务器所有的数据库(数据库文件)、表(表行数)、字段(各字段)等详细信息

USE STAT
GO
SET NOCOUNT ON 

IF EXISTS(SELECT 1 FROM SYS.TABLES WHERE TYPE='U' AND name='DBInfo')
	DROP TABLE DBInfo
IF EXISTS(SELECT 1 FROM SYS.TABLES WHERE TYPE='U' AND name='ColumnsInfo')
	DROP TABLE ColumnsInfo
IF EXISTS(SELECT 1 FROM SYS.TABLES WHERE TYPE='U' AND name='TableInfo')
	DROP TABLE TableInfo
IF EXISTS(SELECT 1 FROM SYS.TABLES WHERE TYPE='U' AND name='ProcInfo')
DROP TABLE ProcInfo
--数据库信息
SELECT D.name AS DBName,
       D.database_id,
	   D.create_date AS DBCreateDate,
	   MF.file_id,
	   MF.type_desc,
	   MF.NAME AS FileName,
	   MF.physical_name,
	   MF.size*8/1024 AS FileSize
	   into DBInfo
FROM SYS.databases D
INNER JOIN SYS.master_files MF
	ON D.database_id = MF.database_id
where D.database_id>4 
and D.name not in ('ReportServer','ReportServerTempDB','STAT')
ORDER BY D.database_id,MF.file_id

CREATE TABLE [dbo].[ColumnsInfo](
	[DBName] [varchar](95) NULL,
	[TableName] [nvarchar](128) NULL,
	[TableDesc] [sql_variant] NULL,
	[Column_id] [int] NULL,
	[ColumnName] [sysname] NULL,
	[PrimaryKey] [nvarchar](1) NULL,
	[IDENTITY] [nvarchar](1) NULL,
	[Computed] [nvarchar](1) NULL,
	[Type] [sysname] NULL,
	[Length] [smallint] NULL,
	[Precision] [tinyint] NULL,
	[Scale] [tinyint] NULL,
	[NullAble] [nvarchar](1) NULL,
	[Default] [nvarchar](max) NULL,
	[ColumnDesc] [sql_variant] NULL,
	[IndexName] [sysname] NULL,
	[IndexSort] [varchar](4) NULL,
	[Create_Date] [datetime] NULL,
	[Modify_Date] [datetime] NULL
) ON [PRIMARY] 

CREATE TABLE [dbo].[ProcInfo](
	[DBName] [varchar](83) NOT NULL,
	[ProcName] [sysname] NOT NULL,
	[object_id] [int] NOT NULL,
	[ProcModifyDate] [datetime] NOT NULL,
	[ProcCreateDate] [datetime] NOT NULL,
	[definition] [nvarchar](max) NULL
) ON [PRIMARY]


CREATE TABLE [dbo].[TableInfo](
	[DBName] [varchar](61) NULL,
	[TableName] [sysname] NULL,
	[object_id] [int] NULL,
	[table_createdate] [datetime] NULL,
	[table_modifydate] [datetime] NULL,
	[rows] [int] NULL
) ON [PRIMARY]


DECLARE @SQL NVARCHAR(MAX)
DECLARE @DBName NVARCHAR(50)
DECLARE TempCursor CURSOR
 FOR 
	SELECT DISTINCT DBName FROM  DBINFO
 OPEN TempCursor  
FETCH NEXT FROM TempCursor INTO @DBName
WHILE @@FETCH_STATUS=0
	BEGIN
		SET @SQL=N'
				USE '+@DBName+'
				--遍历各库的表信息
				;WITH CTE AS(
					SELECT id,rows 
					FROM SYS.sysindexes S
					WHERE indid<2)
				INSERT INTO STAT.DBO.TableInfo
				SELECT '''+@DBName+''' AS DBName,
					   O.name AS TableName,
					   O.object_id,
					   O.create_date as table_createdate,
					   O.modify_date as table_modifydate,
					   CTE.rows
	   
				  FROM SYS.objects O
				  INNER JOIN CTE
					ON CTE.ID=O.object_id
				  WHERE type=''U''  
				  order by DBName,TableName,table_modifydate desc

				--遍历各库的所有字段信息
				INSERT INTO STAT.DBO.ColumnsInfo
				SELECT 
					DBName='''+@DBName+''',
					TableName=CASE WHEN C.column_id=1 THEN O.name ELSE N'''' END,
					TableDesc=ISNULL(CASE WHEN C.column_id=1 THEN PTB.[value] END,N''''),
					Column_id=C.column_id,
					ColumnName=C.name,
					PrimaryKey=ISNULL(IDX.PrimaryKey,N''''),
					[IDENTITY]=CASE WHEN C.is_identity=1 THEN N''√''ELSE N'''' END,
					Computed=CASE WHEN C.is_computed=1 THEN N''√''ELSE N'''' END,
					Type=T.name,
					Length=C.max_length,
					Precision=C.precision,
					Scale=C.scale,
					NullAble=CASE WHEN C.is_nullable=1 THEN N''√''ELSE N'''' END,
					[Default]=ISNULL(D.definition,N''''),
					ColumnDesc=ISNULL(PFD.[value],N''''),
					IndexName=ISNULL(IDX.IndexName,N''''),
					IndexSort=ISNULL(IDX.Sort,N''''),
					Create_Date=O.Create_Date,
					Modify_Date=O.Modify_date
				FROM sys.columns C
					INNER JOIN sys.objects O
						ON C.[object_id]=O.[object_id]
							AND O.type=''U''
							AND O.is_ms_shipped=0
					INNER JOIN sys.types T
						ON C.user_type_id=T.user_type_id
					LEFT JOIN sys.default_constraints D
						ON C.[object_id]=D.parent_object_id
							AND C.column_id=D.parent_column_id
							AND C.default_object_id=D.[object_id]
					LEFT JOIN sys.extended_properties PFD
						ON PFD.class=1 
							AND C.[object_id]=PFD.major_id 
							AND C.column_id=PFD.minor_id
				--             AND PFD.name=''Caption''  -- 字段说明对应的描述名称(一个字段可以添加多个不同name的描述)
					LEFT JOIN sys.extended_properties PTB
						ON PTB.class=1 
							AND PTB.minor_id=0 
							AND C.[object_id]=PTB.major_id
				--             AND PFD.name=''Caption''  -- 表说明对应的描述名称(一个表可以添加多个不同name的描述)
					LEFT JOIN                       -- 索引及主键信息
					(
						SELECT 
							IDXC.[object_id],
							IDXC.column_id,
							Sort=CASE INDEXKEY_PROPERTY(IDXC.[object_id],IDXC.index_id,IDXC.index_column_id,''IsDescending'')
								WHEN 1 THEN ''DESC'' WHEN 0 THEN ''ASC'' ELSE '''' END,
							PrimaryKey=CASE WHEN IDX.is_primary_key=1 THEN N''√'' ELSE N'''' END,
							IndexName=IDX.Name
						FROM sys.indexes IDX
						INNER JOIN sys.index_columns IDXC
							ON IDX.[object_id]=IDXC.[object_id]
								AND IDX.index_id=IDXC.index_id
						LEFT JOIN sys.key_constraints KC
							ON IDX.[object_id]=KC.[parent_object_id]
								AND IDX.index_id=KC.unique_index_id
						INNER JOIN  -- 对于一个列包含多个索引的情况,只显示第1个索引信息
						(
							SELECT [object_id], Column_id, index_id=MIN(index_id)
							FROM sys.index_columns
							GROUP BY [object_id], Column_id
						) IDXCUQ
							ON IDXC.[object_id]=IDXCUQ.[object_id]
								AND IDXC.Column_id=IDXCUQ.Column_id
								AND IDXC.index_id=IDXCUQ.index_id
					) IDX
						ON C.[object_id]=IDX.[object_id]
							AND C.column_id=IDX.column_id
				-- WHERE O.name=N''要查询的表''       -- 如果只查询指定表,加上此条件
				ORDER BY DBName,O.name,C.column_id
				--遍历各库的存储过程及定义
				INSERT INTO STAT.dbo.ProcInfo
				SELECT '''+@DBName+''' AS DBName,
					   P.name AS ProcName,
					   P.object_id,
					   P.modify_date AS ProcModifyDate,
					   P.create_date AS ProcCreateDate,
					   SM.definition 
				FROM SYS.procedures P
				INNER JOIN SYS.sql_modules SM
					ON P.object_id = SM.object_id
				WHERE TYPE=''P''
				'
				--PRINT @SQL
				EXEC (@SQL)
		FETCH NEXT FROM TempCursor INTO @DBName
	END
	CLOSE TempCursor
	DEALLOCATE TempCursor

相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
目录
相关文章
|
30天前
|
存储 Oracle 关系型数据库
服务器数据恢复—华为S5300存储Oracle数据库恢复案例
服务器存储数据恢复环境: 华为S5300存储中有12块FC硬盘,其中11块硬盘作为数据盘组建了一组RAID5阵列,剩下的1块硬盘作为热备盘使用。基于RAID的LUN分配给linux操作系统使用,存放的数据主要是Oracle数据库。 服务器存储故障: RAID5阵列中1块硬盘出现故障离线,热备盘自动激活开始同步数据,在同步数据的过程中又一块硬盘离线,RAID5阵列瘫痪,上层LUN无法使用。
|
2月前
|
PHP 数据库 数据安全/隐私保护
布谷直播源码部署服务器关于数据库配置的详细说明
布谷直播系统源码搭建部署时数据库配置明细!
|
2月前
|
存储 关系型数据库 MySQL
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
873 2
|
2月前
|
SQL
开启慢SQL设置long_query_time=0.1为啥会统计的sql却存在小于100毫秒的sql
开启慢SQL设置long_query_time=0.1为啥会统计的sql却存在小于100毫秒的sql
36 1
|
3月前
|
应用服务中间件 PHP Apache
PbootCMS提示错误信息“未检测到您服务器环境的sqlite3数据库扩展...”
PbootCMS提示错误信息“未检测到您服务器环境的sqlite3数据库扩展...”
|
4月前
|
存储 数据挖掘 数据库
服务器数据恢复—raid磁盘故障导致数据库数据损坏的数据恢复案例
存储中有一组由3块SAS硬盘组建的raid。上层win server操作系统层面划分了3个分区,数据库存放在D分区,备份存放在E分区。 RAID中一块硬盘的指示灯亮红色,D分区无法识别;E分区可识别,但是拷贝文件报错。管理员重启服务器,导致离线的硬盘上线开始同步数据,同步还没有完成就直接强制关机了,之后就没有动过服务器。
|
3月前
|
SQL 存储 关系型数据库
mysql 数据库空间统计sql
mysql 数据库空间统计sql
52 0
|
3月前
|
SQL 数据库
SQL-serve数据库不能连接本地服务器的解决方案
SQL-serve数据库不能连接本地服务器的解决方案
363 0
|
3天前
|
机器学习/深度学习 人工智能 PyTorch
阿里云GPU云服务器怎么样?产品优势、应用场景介绍与最新活动价格参考
阿里云GPU云服务器怎么样?阿里云GPU结合了GPU计算力与CPU计算力,主要应用于于深度学习、科学计算、图形可视化、视频处理多种应用场景,本文为您详细介绍阿里云GPU云服务器产品优势、应用场景以及最新活动价格。
阿里云GPU云服务器怎么样?产品优势、应用场景介绍与最新活动价格参考
|
2天前
|
存储 运维 安全
阿里云弹性裸金属服务器是什么?产品规格及适用场景介绍
阿里云服务器ECS包括众多产品,其中弹性裸金属服务器(ECS Bare Metal Server)是一种可弹性伸缩的高性能计算服务,计算性能与传统物理机无差别,具有安全物理隔离的特点。分钟级的交付周期将提供给您实时的业务响应能力,助力您的核心业务飞速成长。本文为大家详细介绍弹性裸金属服务器的特点、优势以及与云服务器的对比等内容。