SQLServer 列出每个表的列和属性

SQLServer 列出每个表的列和属性,第1张

概述       当需要整理一个数据库帮助文档是,可能需要列出库中每个表的列及其属性。这可能在开发一些接口或者外包给别的公司时有帮助。如果需要别人打开SQL Server Management Studio (SSMS)来一个一个查看,无疑是一种折磨。        解决这个问题可以考虑使用系统的目录视图:sys.tables、sys.all_columns、sys.types Sys.tables:

       当需要整理一个数据库帮助文档是,可能需要列出库中每个表的列及其属性。这可能在开发一些接口或者外包给别的公司时有帮助。如果需要别人打开sql Server Management Studio (SSMS)来一个一个查看,无疑是一种折磨。


       解决这个问题可以考虑使用系统的目录视图:sys.tables、sys.all_columns、sys.types


Sys.tables:

       提供数据库中每个表对应的一行数据。包括用户表和系统表。而其中的is_ms_shipped列,代表是否为系统表。这在你需要仅仅显式用户表的时候很有用。而不需要在sys.sysobject兼容性视图中通过type=’U’来筛选。


Sys.all_columns:

       数据库每一个对象的每一列都会返回一行,很多列和sys.type是相同的。但是有些列只能在sys.type中查找。


Sys.types:


      此目录视图存储系统或者用户自定义数据类型及它们的属性。本文中所需的是数据类型的名字,这列在sys.all_columns中是没有的。同时数据库的排序规则会影响sys.types,所以对于系统内置类型如text,ntext,vachar(),char(),nvarchar(),nchar()会因为数据库不同而不同。


       如非必须,最好只查询当前数据库的内容而不要跨数据库,因为这些视图是基于单个数据库的。运行以下语句:


USE AdventureWorksGOSELECT  OBJECT_SCHEMA_name(T.[object_ID],DB_ID()) AS [架构名],T.[name] AS [表名],AC.[name] AS [列名],TY.[name] AS [系统数据类型],TY.is_user_defined AS [是否用户自定义类型],--1 = 用户定义类型,0 = sql Server 系统数据类型        AC.[max_length] [最大长度],AC.[precision] [精确度],--如果列包含的是数值,则为该列的精度;否则为0        AC.[scale] [数值范围],--如果列包含的是数值,则为列的小数位数;否则为0        AC.[is_nullable] [是否允许为空],AC.[is_ansi_padded][是否使用ANSI_padding]--1 = 如果列为字符、二进制或变量类型,则该列使用ANSI_padding ON 行为FROM    sys.[tables] AS T        INNER JOIN sys.[all_columns] AC ON T.[object_ID] = AC.[object_ID]        INNER JOIN sys.[types] TY ON AC.[system_type_ID] = TY.[system_type_ID]                                     AND AC.[user_type_ID] = TY.[user_type_ID]WHERE   T.[is_ms_shipped] = 0ORDER BY T.[name],AC.[column_ID]



可以得到:




由于某些原因需要在别的库上查询另外一个库的信息时,需要硬编码,如下,可以得到相同的结果:


USE [master] GOSELECT  OBJECT_SCHEMA_name(T.[object_ID],DB_ID('AdventureWorks')) AS [架构名],AC.[is_ansi_padded][是否使用ANSI_padding]--1 = 如果列为字符、二进制或变量类型,则该列使用ANSI_padding ON 行为FROM    AdventureWorks.sys.[tables] AS T        INNER JOIN AdventureWorks.sys.[all_columns] AC ON T.[object_ID] = AC.[object_ID]        INNER JOIN AdventureWorks.sys.[types] TY ON AC.[system_type_ID] = TY.[system_type_ID]                                     AND AC.[user_type_ID] = TY.[user_type_ID]WHERE   T.[is_ms_shipped] = 0ORDER BY T.[name],AC.[column_ID]
最后,通过这些查询结果,可以把数据导出到excel里面供使用。 总结

以上是内存溢出为你收集整理的SQLServer 列出每个表的列和属性全部内容,希望文章能够帮你解决SQLServer 列出每个表的列和属性所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1175888.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存