原文: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 SERVER统计服务器所有的数据库(数据库文件)、表(表行数)、字段(各字段)等详细信息的更多相关文章

  1. SQL Server返回插入数据的ID和受影响的行数

    首先看看数据库里面的数据(S_Id为自增长标识列): sql server 中返回上一次插入数据的ID(标识值)有三种方式: 第一种 @@IDENTITY: insert into Student(S ...

  2. SQL SERVER 2008 服务器登录名、角色、数据库用户、角色、架构的关系

    sql server登录名.服务器角色.数据库用户.数据库角色.架构区别联系 1.一个数据库用户可以对应多个架构(架构是表容器).架构里面包含的是数据库表. 2.一个数据库角色有可能涉及多个架构.数据 ...

  3. 转:SQL Server中服务器角色和数据库角色权限详解

    当几个用户需要在某个特定的数据库中执行类似的动作时(这里没有相应的Windows用户组),就可以向该数据库中添加一个角色(role).数据库角色指定了可以访问相同数据库对象的一组数据库用户. 数据库角 ...

  4. SQL Server代理(4/12):配置数据库邮件

    SQL Server代理是所有实时数据库的核心.代理有很多不明显的用法,因此系统的知识,对于开发人员还是DBA都是有用的.这系列文章会通俗介绍它的很多用法. 在以前的文章里我们看到,SQL Serve ...

  5. SQL Server DBA日常查询视图_数据库对象视图

    1.数据库 use master; exec sp_helpdb 1.1查询数据库大小 1.2查询数据库状态 use msdb select name, user_access_desc, --用户访 ...

  6. 解决SQL Server管理器无法连接远程数据库Error: 1326错误

    解决SQL Server管理器无法连接远程数据库Error: 1326错误 我们在在使用SQL Server时都会遇到使用SQL Server Management Studio无法连接远程数据库实例 ...

  7. 使用SQL Server Management Studio 创建作业备份数据库

    在项目中,经常需要备份数据库,如果能做到只需点个按钮(“开始备份数据库”按钮),然后什么都不管,数据库就自动备份好了,或者服务器上的数据库隔一段时间自动备份一次,那该多好啊. Sql server 的 ...

  8. SQL Server如何附加只有mdf的数据库文件

    有时候SQL Server意外断电会导致SQL Server的ldf日志文件丢失或者损坏,这个时候你如果直接附加mdf文件到SQL Server会失败,这里提供一个方法可以还原只有mdf的数据库文件, ...

  9. 为何SQL SERVER使用sa账号登录还原数据库BAK文件失败,但是使用windows登录就可以

    今天发现一个问题,就是公司开发服务器上的sql server使用sa账号登录后,还原一个数据库bak文件老是报错,错误如下: TITLE: Microsoft SQL Server Managemen ...

随机推荐

  1. MVC5中使用SignalR2.0实现实时聊天室

    原文 MVC5中使用SignalR2.0实现实时聊天室 有时候需要浏览器和服务端保持实时的通讯(比如在线聊天),SignalR的出现让这一切变得非常简单.它能够让服务端向客户端实时的推送消息.如果用户 ...

  2. android(9)_数据存储和访问3_scard基本介绍

    使用Activity的openFileOutput()保存文件的方法,文件存储在手机空间,通常情况下,手机的存储空间不是很大,存储小文件确定.假设你要存储大文件,如视频,是不可行. 对于这样大的文件, ...

  3. FutureTask解析(转)

    站在使用者的角度,future是一个经常在多线程环境下使用的Runnable,使用它的好处有两个:1. 线程执行结果带有返回值2. 提供了一个线程超时的功能,超过超时时间抛出异常后返回. 那,怎么实现 ...

  4. net 试图加载格式不正确的程序。(Exception from HRESULT: 0x8007000B)

    原文:net 试图加载格式不正确的程序.(Exception from HRESULT: 0x8007000B) Server Error in '/' Application. 试图加载格式不正确的 ...

  5. thoughtworks笔试整理

    笔试了,时间1个半小时.没想到居然有7/10是开放性问题.大意例如以下:1.为什么选择增加ThoughtWorks.200字以内,不能用"interesting"."ch ...

  6. OS X升级到10.10使用后pod故障解决方案出现

    最新的mac 10.10强大的好奇心,所以,你的系统升级到10.10.结果表明,使用pod出现下述问题: /System/Library/Frameworks/Ruby.framework/Versi ...

  7. NYNU_省赛选拔题(5)

    题目描述 P 的一家要出去旅游,买了当地的地图,发现各地分别由各个景点,若 P 想使家人分队去景点,尽快到达各个景点(必须所有景点),并且最终所有家人都到达 M 所在的景点.   你用程序告诉 P 最 ...

  8. ASP.NET MVC+EF框架+EasyUI实现权限管理系列(6)- EF上下文实例管理

    原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(6)- EF上下文实例管理 ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇)   (1):框架搭建    ( ...

  9. I2C驱动程序框架probe道路

    基于Linux的I2C驱动器.采纳probe道路.根据这个框架,如下面就可以写任何支持I2C总线设备Linux驱动器. I2C设备连接到cpu具体i2c接口.被安装在cpu的i2c适配器.i2c设备和 ...

  10. Ubuntu通过使用PyCharm 进行调试 Odoo 8.0 可能出现的问题

    实现步骤,请移步http://shine-it.net/index.php?topic=16603.0 要么 http://www.mindissoftware.com/2014/09/11/Run- ...