MS SQL 模仿ORACLE的DESC
前言: 在ORACLE数据库的SQL*PLUS里面有个DES(DESCRIBE)命令,它可以返回数据库所存储对象的描述,如下所示
SQL> DESC STUDENT_SCORE
Name Type Nullable Default Comments
---------------- ---------- -------- ------- --------
STUDENT_NO NUMBER(10) 学号
CHINESE_SCORE NUMBER Y 语文成绩
ENGLISH_SCORE NUMBER Y 英语成绩
MATH_SOCRE NUMBER Y 数学成绩
PHYSICAL_SCORE NUMBER Y 物理成绩
SPORTS_SCORE NUMBER Y 体育成绩
CHEMICAL_SCORE NUMBER Y 化学成绩
BIOLOGICAL_SCORE NUMBER Y 生物成绩
DESC可以获取表、视图等的字段名、字段类型、以及字段注释等信息。在开发过程中,这个命令非常实用,方便,也是使用频率比较高的命令,在MS SQL中没有这个命令,倒是有个sp_help命令,也比较方便,获取的信息甚至比DESC命令还多,但是它有个缺陷,不能获取字段的注释信息,有时候给你来一堆你不想关注的信息。下面我们我们来创建一个存储过程,模拟实现DESC命令的功能以及定制一些你想要的功能。希望这个存储过程能方便大家的工作。初版代码如下:
- SET ANSI_NULLS ON;
- GO
- SET QUOTED_IDENTIFIER ON
- GO
- IF EXISTS(SELECT 1 FROM sysobjects WHEREid=OBJECT_ID(N'sp_desc')
- AND OBJECTPROPERTY(id, 'IsProcedure') =1)
- DROP PROCEDURE sp_desc;
- GO
- --==================================================================================================
- -- ProcedureName : sp_desc
- -- Author : Kerry
- -- CreateDate : 2013-05-13
- -- Blog : www.cnblogs.com/kerrycode/
- -- Description : 模仿ORACLE的SQLPLUS命令DESC,并且参考sp_help相关
- -- 增强功能
- /***************************************************************************************************
- Parameters : 参数说明
- ****************************************************************************************************
- @ObjName : 需要查看的对象名称,例如表名、视图等
- ****************************************************************************************************
- Modified Date Modified User Version Modified Reason
- ****************************************************************************************************
- 2013-05-19 Kerry V01.00.01 增加Print信息,提示输出内容
- ***************************************************************************************************/
- --==================================================================================================
- CREATE PROCEDURE sp_desc
- (
- @ObjName VARCHAR(32)
- )
- AS
- SET NOCOUNT ON;
- DECLARE @ObjectId INT;
- DECLARE @Sysobj_Type CHAR(2);
- IF @ObjName IS NULL
- BEGIN
- PRINT 'you must assign the parameter @ObjNam';
- RETURN 0;
- END
- SELECT @ObjectId = object_id, @Sysobj_Type=type FROM sys.all_objects
- WHERE object_id =OBJECT_ID(@ObjName);
- IF @Sysobj_Type ='U' AND @ObjectId > 0
- BEGIN
- SELECT N'************表的功能描述信息**********' AS N'表的功能描述信息';
- --表的功能描述信息
- SELECT ISNULL(value, '麻烦补齐表的功能描述信息') AS Table_Desc
- FROM sys.extended_properties
- WHERE major_id = @ObjectId
- AND minor_id = 0
- SELECT N'************表结构基本信息************' AS N'表结构基本信息';
- --列出表结构的基本信息
- SELECT C.Name AS Column_Nam ,
- CASE WHEN T.Name = 'nvarchar'
- THEN T.name + '(' + CAST(C.max_length / 2 AS VARCHAR) + ')'
- ELSE T.name
- END AS Data_Type ,
- CASE WHEN C.Max_Length = -1 THEN 'Max'
- ELSE CAST(C.Max_Length AS VARCHAR)
- END AS Max_Length ,
- C.Precision ,
- C.Scale ,
- CASE WHEN C.is_nullable = 0 THEN '×'
- ELSE '√'
- END AS Is_Nullable ,
- ISNULL(CAST(I.seed_value AS VARCHAR) + '-'
- + CAST(I.increment_value AS VARCHAR), '') AS Is_Identity ,
- ISNULL(M.text, '') AS Default_Value ,
- ISNULL(P.value, '') AS Column_Comments
- FROM sys.columns C
- INNER JOIN sys.types T ON C.system_type_id = T.user_type_id
- LEFT JOIN dbo.syscomments M ON M.id = C.default_object_id
- LEFT JOIN sys.extended_properties P ON P.major_id = C.object_id
- AND C.column_id = P.minor_id
- LEFT JOIN sys.identity_columns I ON I.column_id = C.column_id
- AND C.object_id = I.object_id
- WHERE C.[object_id] = @ObjectId
- ORDER BY C.Column_Id ASC;
- SELECT N'**********表约束基本信息************' AS N'表约束基本信息';
- --表的约束信息
- SELECT name ,
- type
- FROM sys.objects
- WHERE parent_object_id = @ObjectId
- AND type IN( 'C ', 'PK', 'UQ', 'F ', 'D ' ) ;
- SELECT N'********表的索引基本信息********' AS N'表的索引基本信息';
- --±表的索引信息
- SELECT i.index_id ,
- i.data_space_id ,
- i.name ,
- CASE WHEN type = 0 THEN '堆'
- WHEN type = 1 THEN '聚集索引'
- WHEN type = 2 THEN '非聚集索引'
- WHEN type = 3 THEN 'XML'
- WHEN TYPE = 4 THEN '空间'
- END AS [type] ,
- i.ignore_dup_key ,
- i.is_unique ,
- i.is_hypothetical ,
- i.is_primary_key ,
- i.is_unique_constraint ,
- s.auto_created ,
- s.no_recompute
- FROM sys.indexes i
- JOIN sys.stats s ON i.object_id = s.object_id
- AND i.index_id = s.stats_id
- WHERE i.object_id = @ObjectId;
- SELECT N'********索引包含那些字段********' AS '索引字段信息';
- SELECT d.name, i.index_id, c.name
- FROM sys.indexes d
- INNER JOIN sys.index_columns i ON d.object_id = i.object_id
- LEFT JOIN sys.columns c ON i.object_id = c.object_id
- AND i.index_column_id = c.column_id
- WHERE d.object_id = @ObjectId;
- SELECT N'********表的触发器基本信息********' AS N'触发器信息';
- --表的触发器信息
- SELECT trigger_name = name ,
- trigger_owner = USER_NAME(OBJECTPROPERTY(object_id, 'ownerid')) ,
- isupdate = OBJECTPROPERTY(object_id, 'ExecIsUpdateTrigger') ,
- isdelete = OBJECTPROPERTY(object_id, 'ExecIsDeleteTrigger') ,
- isinsert = OBJECTPROPERTY(object_id, 'ExecIsInsertTrigger') ,
- isafter = OBJECTPROPERTY(object_id, 'ExecIsAfterTrigger') ,
- isinsteadof = OBJECTPROPERTY(object_id, 'ExecIsInsteadOfTrigger') ,
- trigger_schema = SCHEMA_NAME(schema_id)
- FROM sys.objects
- WHERE parent_object_id = @ObjectId
- AND type IN( 'TR', 'TA' ) ;
- END
- ELSE IF @Sysobj_Type ='V' AND @ObjectId > 0
- BEGIN
- SELECT N'*********视图的功能描述信息**********' AS N'视图的功能描述信息';
- --视图的功能描述信息
- SELECT ISNULL(value, N'麻烦补齐描述该视图功能的信息') AS View_Desc
- FROM sys.extended_properties
- WHERE major_id = @ObjectId
- AND minor_id = 0
- SELECT '*************视图基本信息*****************' AS N'视图基本信息';
- SELECT C.Name AS Column_Nam ,
- CASE WHEN T.Name = 'nvarchar'
- THEN T.name + '(' + CAST(C.max_length / 2 AS VARCHAR) + ')'
- ELSE T.name
- END AS Data_Type ,
- CASE WHEN C.Max_Length = -1 THEN 'Max'
- ELSE CAST(C.Max_Length AS VARCHAR)
- END AS Max_Length ,
- C.Precision ,
- C.Scale ,
- CASE WHEN C.is_nullable = 0 THEN '×'
- ELSE '√'
- END AS Is_Nullable ,
- ISNULL(CAST(I.seed_value AS VARCHAR) + '-'
- + CAST(I.increment_value AS VARCHAR), '') AS Is_Identity ,
- ISNULL(M.text, '') AS Default_Value ,
- ISNULL(P.value, '') AS Column_Comments
- FROM sys.columns C
- INNER JOIN sys.types T ON C.system_type_id = T.user_type_id
- LEFT JOIN dbo.syscomments M ON M.id = C.default_object_id
- LEFT JOIN sys.extended_properties P ON P.major_id = C.object_id
- AND C.column_id = P.minor_id
- LEFT JOIN sys.identity_columns I ON I.column_id = C.column_id
- AND C.object_id = I.object_id
- WHERE C.[object_id] = @ObjectId
- ORDER BY C.Column_Id ASC;
- SELECT '**********视图脚本***********' AS '视图脚本';
- EXEC sp_helptext @ObjName;
- END
- ELSE IF @Sysobj_Type ='P' AND @ObjectId > 0
- BEGIN
- SELECT N'*********描述存储过程功能信息**********' AS N'描述存储过程功能信息';
- --存储过程的功能描述信息
- SELECT ISNULL(value, N'麻烦补齐描述该存储过程功能的信息') AS View_Desc
- FROM sys.extended_properties
- WHERE major_id = @ObjectId
- AND minor_id = 0;
- EXEC sp_help @ObjName;
- END
- ELSE IF @Sysobj_Type IN('IF') AND @ObjectId > 0
- BEGIN
- SELECT N'*********描述自定义函数功能信息**********' AS N'描述自定义函数功能信息';
- --描述自定义函数功能信息
- SELECT ISNULL(value, N'麻烦补齐描述该自定义函数功能的信息') AS View_Desc
- FROM sys.extended_properties
- WHERE major_id = @ObjectId
- AND minor_id = 0;
- SELECT 'Name' = o.name ,
- 'Owner' = USER_NAME(OBJECTPROPERTY(object_id, 'ownerid')) ,
- 'Object_type' = SUBSTRING(v.name, 5, 31)
- FROM sys.all_objects o ,
- master.dbo.spt_values v
- WHERE o.object_id =@ObjectId AND o.type = SUBSTRING(v.name, 1, 2) COLLATE database_default
- AND v.type = 'O9T'
- ORDER BY [Owner] ASC ,
- Object_type DESC ,
- Name ASC
- END
- GO
接下来,我们新建一张表来看看效果如何,视图,存储过程、自定义函数就不大战篇幅去展示了,一个例子就OK了,有兴趣的,自己试试
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
IF EXISTS(SELECT * FROM sysobjects WHERE id=OBJECT_ID(N'Employee') AND type='U')
DROP TABLE dbo.Employee;
GO
CREATE TABLE Employee
(
Employee_ID INT IDENTITY(1,1) ,
Employee_Name NVARCHAR(12) ,
Sex SMALLINT DEFAULT(1),
Department_ID INT ,
Salary FLOAT ,
WorkYear INT ,
CONSTRAINT PK_Employee PRIMARY KEY(Employee_ID)
);
EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'员工编号' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'Employee', @level2type=N'COLUMN',@level2name=N'Employee_ID'
GO
EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'员工姓名' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'Employee', @level2type=N'COLUMN',@level2name=N'Employee_Name'
GO
EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'性别' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'Employee', @level2type=N'COLUMN',@level2name=N'Sex'
GO
EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'部门编号' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'Employee', @level2type=N'COLUMN',@level2name=N'Department_ID'
GO
EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'薪水' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'Employee', @level2type=N'COLUMN',@level2name=N'Salary'
GO
EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'工龄' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'Employee', @level2type=N'COLUMN',@level2name=N'WorkYear'
GO
EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'员工信息表' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'TABLE',@level1name=N'Employee'
CREATE TRIGGER TR_Employee_Salary ON Employee
AFTER INSERT
AS
DECLARE @Salary FLOAT;
SELECT @Salary = Salary FROM INSERTED;
IF (@Salary < 0)
BEGIN
RAISERROR('The Salary Small than 0 ',10,1);
ROLLBACK TRANSACTION;
END
GO
CREATE VIEW V_Employee
AS
SELECT Employee_ID, Employee_Name, WorkYear FROM Employee
EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'员工信息表' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'VIEW',@level1name=N'V_Employee'
EXEC sys.sp_addextendedproperty @name=N'MS_Description', @value=N'给用户批量赋权限的存储过程' , @level0type=N'SCHEMA',@level0name=N'dbo', @level1type=N'PROCEDURE',@level1name=N'sp_authorize_right'
执行存储过程,你可以获取表Employee的基本信息了,如下所示

MS SQL 模仿ORACLE的DESC的更多相关文章
- MS SQL到Oracle的数据迁移笔记
MS SQL到Oracle的数据迁移笔记 一.任务背景 旧系统使用MS SQL Server数据库,新系统使用Oracle数据库,现在需要将旧系统中的数据迁移到新系统中,旧数据按照约定的规则转换后,能 ...
- mysql、MS SQL关于分页的sql查询语句 limit 和row_number() OVER函数
在做项目的时候需要些分页,用的数据库是MySQL,之前看到的参考例子是用MS SQL做的,在MS SQL.Oracle里面有ROW_NUMBER() OVER函数可以在数据库里对数据进行分组.百度后的 ...
- iBatis自动生成的主键 (Oracle,MS Sql Server,MySQL)【转】
iBatis的sqlMap配置文件的selectKey元素有个type属性,可以指定pre或者post表示前生成(pre)还是后生成(post). Oracle设置 <!-- Oracle SE ...
- Oracle\MS SQL Server Update多表关联更新
原文:Oracle\MS SQL Server Update多表关联更新 一条Update更新语句是不能更新多张表的,除非使用触发器隐含更新.而表的更新操作中,在很多情况下需要在表达式中引用要更新的表 ...
- 关于64位 MS SQL 导入导出 Oracle 引发 ORA-06413 的解决方法
如果在X64系统下我们想利用 MS SQL 的DTS导入导出 Oracle 数据,由 oracle 不支持路径中包含")",会引发 ORA-06413:连接未打开错误 解决的办法很 ...
- ms sql server,oracle数据库实现拼接一列的多行内容
项目中要将查询出的一列的多行内容拼接成一行,如下图:ypmc列. ms sql server: 网上查到相关资料如下:http://blog.csdn.net/rolamao/article/deta ...
- SSIS 从oracle 转数据回MS SQL
SSIS 从oracle 转数据回MS SQL,转每月的销售记录,大概15000以内,在开发机器上没问题,部署到生产环境出现各种状况“ SSIS 无法从连接伺服器的OLE DB提供者BULK 提取资料 ...
- MS SQL 监控数据/日志文件增长
前几天,在所有数据库服务器部署了监控磁盘空间的存储过程和作业后(MS SQL 监控磁盘空间告警),今天突然收到了两封告警邮件,好吧,存储规划是一方面,但是,是不是要分析一下是什么原因造成磁盘空 ...
- MS SQL巡检系列——检查重复索引
前言感想:一时兴起,突然想写一个关于MS SQL的巡检系列方面的文章,因为我觉得这方面的知识分享是有价值,也是非常有意义的.一方面,很多经验不足的人,对于巡检有点茫然,不知道要从哪些方面巡检,另外一方 ...
随机推荐
- 分享用于学习C++音频处理的代码示例
与<分享用于学习C++图像处理的代码示例>为姊妹篇. 为了便于学习C++音频处理并研究音频算法, 俺写了一个适合初学者学习的小小框架. 麻雀虽小五脏俱全,仅仅考虑单通道处理. 采用Deco ...
- Android查缺补漏(View篇)--事件分发机制
事件分发机制是Android中非常重要的一个知识点,同时也是难点,相信到目前为止很多Android开发者对事件分发机制并没有一个非常系统的认识,当然也包括博主个人在内.可能在平时的开发工作中我们并没有 ...
- VS Code 快捷键(中英文对照版)
原文地址:https://segmentfault.com/a/1190000007688656 常用 General 按 Press 功能 Function Ctrl + Shift + P,F1 ...
- python网络数据采集(低音曲)
废话不多说,马上开始. 上次我们说到遍历单个域名,今天我们来写一个爬对应词条的脚本,他会遍历整个网址直到爬完对应词条. 代码: from urllib.request import urlopen f ...
- Digit Generator(水)
题目链接:http://acm.tju.edu.cn/toj/showp2502.html2502. Digit Generator Time Limit: 1.0 Seconds Memor ...
- Logstash+Kibana部署配置
Logstash是一个接收,处理,转发日志的工具.支持系统日志,webserver日志,错误日志,应用日志,总之包括所有可以抛出来的日志类型. 典型的使用场景下(ELK): 用Elasticsearc ...
- BLE空中升级 谈(二)
BLE 空中升级谈 -- CC2541 的产品开发中OAD注意事项(续) TI CC2541支持多个硬件,多个软件对它进行空中升级,可以有不同的组合,硬件有 编号 名称 Hex 用法 1 Cc2540 ...
- Angular 选项卡
<div ng-init="now=0;" class="nav"> <h4>选项卡</h4> <div > & ...
- javascript之事件监听
addEventListener是一个监听事件并处理相应的函数,用于向指定元素添加事件句柄,可使用removeEventListener()方法来移除addEventListener()方法添加的事件 ...
- Laravel5中使用阿里大于(鱼)发送短信验证码
在做用户注册和个人中心的安全管理时,我实现借助第三方短信平台(阿里大于(鱼))在Laravel框架中进行手机验证的设置:阿里大于,是阿里通信旗下优质便捷的云通信服务平台,整合了三大运营商的通信能力,为 ...