首页 > 数据库技术 > 详细

使用SQL生成指定数据库的数据字典(MSSQL)

时间:2019-11-28 10:48:20      阅读:114      评论:0      收藏:0      [点我收藏+]
USE DBNAME --指定要生成数据字典的数据库

GO
SELECT
	表名=
CASE
		
		WHEN a.colorder= 1 THEN
		d.name ELSE ‘‘ 
	END, 表说明=
CASE
	
	WHEN a.colorder= 1 THEN
	isnull( f.value, ‘‘ ) ELSE ‘‘ 
	END, 字段序号= a.colorder, 字段名= a.name, 标识=
CASE
	
	WHEN COLUMNPROPERTY( a.id, a.name, ‘IsIdentity‘ ) = 1 THEN
	‘√‘ ELSE ‘‘ 
	END, 主键=
CASE
	
	WHEN EXISTS (
	SELECT
		1 
	FROM
		sysobjects 
	WHERE
		xtype = ‘PK‘ 
		AND name IN ( 
			SELECT name FROM sysindexes WHERE indid IN ( 
				SELECT indid FROM sysindexkeys WHERE id = a.id AND colid = a.colid ) ) 
		) THEN
		‘√‘ ELSE ‘‘ 
	END, 
	类型= b.name, 
	占用字节数= a.length, 
	长度= COLUMNPROPERTY( a.id, a.name, ‘PRECISION‘ ), 
	小数位数= isnull( COLUMNPROPERTY( a.id, a.name, ‘Scale‘ ), 0 ), 
	允许空=CASE
		
		WHEN a.isnullable= 1 THEN
		‘√‘ ELSE ‘‘ 
	END, 
	默认值= isnull( e.text, ‘‘ ), 
	字段说明= isnull( g.[value], ‘‘ ) 
FROM
	syscolumns a
	LEFT JOIN systypes b ON a.xtype= b.xusertype
	INNER JOIN sysobjects d ON a.id= d.id 
	AND d.xtype= ‘U‘ 
	AND d.name<> ‘dtproperties‘
	LEFT JOIN syscomments e ON a.cdefault= e.id
	LEFT JOIN sys.extended_properties g ON a.id= g.major_id 
	AND a.colid= g.minor_id
	LEFT JOIN sys.extended_properties f ON d.id= f.major_id 
	AND f.minor_id = 0 
--where d.name=‘要查询的表‘ --如果只查询指定表,加上此条件
ORDER BY
	a.id,
	a.colorder

使用SQL生成指定数据库的数据字典(MSSQL)

原文:https://www.cnblogs.com/ykbb/p/11946967.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!