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

原文: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
时间: 2024-09-20 16:35:53

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

在SQL Server 2000里设置和使用数据库复制

2005-08 余枫                                        在SQL Server 2000里设置和使用数据库复制之前,应先检查相关的几台SQL Server服务器下面几点是否满足:        1.MSSQLserver和Sqlserveragent服务是否是以域用户身份启动并运行的(.\administrator用户也是可以的)            如果登录用的是本地系统帐户local,将不具备网络功能,会产生以下错误:              

SQL Server 2005 镜像构建手册(sql2005数据库同步镜像方案)_mssql2005

一. 镜像简介 1. 简介 数据库镜像是将数据库事务处理从一个SQL Server数据库移动到不同SQL Server环境中的另一个SQL Server数据库中.镜像不能直接访问;它只用在错误恢复的情况下才可以被访问. 要进行数据库镜像所需的最小需求包括了两个不同的SQL Server运行环境.主服务器被称为"主机",第二个服务器被称作"备机".主机数据库就是你实际用着的数据库,镜像数据库就是你的数据库的备用拷贝.当事务写入你的基本服务器的时候,他们也同样被传送到并

SQL Server通过重建方式还原master数据库_MsSql

SQL Server通过重建方式还原master数据库,具体内容如下 1.备份master数据库 2.停止服务,直接删除master数据文件 3.用安装程序重建master数据文件 控制台下进入安装目录就不说了 D:\SetUp\sqlserver2012>Setup /QUIET /ACTION=REBUILDDATABASE /INSTANCENAME=sqlserver2012 /SQLSYSADMINACCOUNTS=UserName /SAPWD= *** 4.单用户模式启动SQL S

SQL Server通过重建方式还原master数据库

SQL Server通过重建方式还原master数据库,具体内容如下 1.备份master数据库 2.停止服务,直接删除master数据文件 3.用安装程序重建master数据文件 控制台下进入安装目录就不说了 D:\SetUp\sqlserver2012>Setup /QUIET /ACTION=REBUILDDATABASE /INSTANCENAME=sqlserver2012 /SQLSYSADMINACCOUNTS=UserName /SAPWD= *** 4.单用户模式启动SQL S

SQL Server大型服务器:伸缩性、可用性与易管理性

简介 随着电子商务.在线商务应用.商务智能等领域的迅猛发展,许多成功的企业都在对其在线应用进行扩展.目前,每一个Internet或企业内部网络用户都是一个潜在的客户,因此,应用面临着巨大的用户和事务负载.绝大多数企业都在建立大型服务器,以便管理数以吉计的信息并为数以百万的客户和用户提供支持.在此过程中,数据库系统已成为这些大型服务器的核心. 可伸缩式系统为您提供了一种通过添加更多硬件设备的简单方式来扩展网络.服务器.数据库及应用程序的途径.可伸缩式计算机系统可在无需修改应用程序代码的情况下扩大应

SQL Server 链接服务器的安全

原文:SQL Server 链接服务器的安全 一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 安全设置(Security Settings) 实现效果:用户A能看见能使用,B用户不能看见这个链接服务器: 实现效果:用户A能看见能使用,B用户能看见但是没有权限使用: 总结 参考文献(References) 二.背景(Contexts) 当需要用远程服务器数据库和本地进行数据交互的时候(例如导数据等),我们通常会在本地创建一个远程服务器的数据

SQL Server 2008服务器合并功能介绍

SQL Server 2008提供了一个具有企业级管理能力和性能的灵活的服务器合并解决方案,降低了硬件和 维护的成本. 灵活的.可管理的和可扩展的数据服务合并 灵活性 选择最适合你业务的数据服务合并解决方案 · 合并具有多个数据库和实例的服务器 使用SQL Server 2008在一个单独的服务器实例中存放多个数据库,以便集中数据存储和管理.在一个 单独的服务器上运行多个SQL Server 2008的实例以便保持数据库应用的独立性,同时还降低了硬件成本 .许可成本和管理费用. · 通过虚拟化合

SQL Server跨服务器连接的多种方法

本文对SQL Server跨服务器连接的方式进行总结. 1.OPENDATASOURCE 在SQL文中直接用此语句打开数据库示例: OPENDATASOURCE( 'SQLOLEDB','Data Source=TQDBSV001 ;User ID=fish;Password=2312').RackDB.dbo.CS 此方式较为简单,但存在弊端就是速度很慢. 2.OPENROWSET 包括从 OLE DB 资料来源存取远端资料需要的所有连线资讯.这个方法是在连结伺服器存取资料表的替代方法,而且是

sql server统计一个字段出现的次数的问题

问题描述 sql server统计一个字段出现的次数的问题 从选课表和课程表中查询每门选修课的人数,查询结果中显示人数.课程名称,按人数降序排序sc表sid cid grade2005216001 16020010 96.02005216001 16020011 80.02005216002 16020010 67.02005216003 16020012 78.02005216003 16020013 87.02005216003 16020014 85.02005216111 1602001