服务器之家

服务器之家 > 正文

获取MSSQL数据字典的SQL语句

时间:2019-11-05 14:54     来源/作者:mssql教程网

代码如下:


CREATE VIEW dbo.vw_db_dictionary 
AS 
SELECT TOP 100 PERCENT dbo.sysobjects.name AS table_name, 
dbo.sysproperties.[value] AS table_desc, dbo.syscolumns.name AS field, 
properties.[value] AS field_desc, dbo.systypes.name AS field_type, 
dbo.syscolumns.length AS field_size, 
ISNULL(COLUMNPROPERTY(dbo.syscolumns.id, dbo.syscolumns.name, 'Scale'), 0) 
AS field_precision, dbo.syscolumns.isnullable AS nullable, 
CASE WHEN syscomments.text IS NULL 
THEN '' ELSE syscomments.text END AS default_value, 
CASE WHEN COLUMNPROPERTY(syscolumns.id, syscolumns.name, 'IsIdentity') 
= 1 THEN '√' ELSE '' END AS is_identity, 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 = syscolumns.id AND colid = syscolumns.colid))) 
THEN '√' ELSE '' END AS is_key 
FROM dbo.syscolumns INNER JOIN 
dbo.sysobjects ON dbo.sysobjects.id = dbo.syscolumns.id INNER JOIN 
dbo.systypes ON dbo.syscolumns.xtype = dbo.systypes.xtype LEFT OUTER JOIN 
dbo.sysproperties properties ON dbo.syscolumns.id = properties.id AND 
dbo.syscolumns.colid = properties.smallid LEFT OUTER JOIN 
dbo.sysproperties ON dbo.sysobjects.id = dbo.sysproperties.id AND 
dbo.sysproperties.smallid = 0 LEFT OUTER JOIN 
dbo.syscomments ON dbo.syscolumns.cdefault = dbo.syscomments.id 
WHERE (dbo.sysobjects.xtype = 'U') 
ORDER BY dbo.sysobjects.name

相关文章

热门资讯

玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分 2019-06-21
男生常说24816是什么意思?女生说13579是什么意思?
男生常说24816是什么意思?女生说13579是什么意思? 2019-09-17
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情
华为nova5pro和p30pro哪个好 华为nova5pro和华为p30pro对比详情 2019-06-22
Nginx服务器究竟是怎么执行PHP项目
Nginx服务器究竟是怎么执行PHP项目 2019-05-24
超A是什么意思 你好a表达的是什么
超A是什么意思 你好a表达的是什么 2019-06-06
返回顶部