我有一个SQL Server数据库,我想知道它有什么列和类型。我更喜欢通过查询而不是使用像Enterprise Manager这样的GUI来实现这一点。有办法做到这一点吗?
当前回答
试一试:
EXEC [ServerName].[DatabaseName].dbo.sp_columns 'TableName'
你可以得到一些表结构的信息,比如:
Table_qualifier, table_owner, table_name, column_name, data_type, type_name…
其他回答
有几个方法可以获取一个表的元数据:
EXEC sp_help tablename
将返回几个结果集,描述表、它的列和约束。
INFORMATION_SCHEMA视图将为您提供所需的信息,但不幸的是,您必须手动查询这些视图并连接它们。
使用此查询
Select * From INFORMATION_SCHEMA.COLUMNS Where TABLE_NAME = 'TABLENAME'
SQL Server中与Oracle的describe命令等价的是存储的proc sp_help
describe命令提供了列名、类型、长度等信息。
在SQL Server中,假设你想在数据库'mydb'中的模式'myschema'中描述一个表'mytable',你可以这样做:
USE mydb;
exec sp_help 'myschema.mytable';
如果你正在使用Brent Ozar团队的FirstResponderKit,你也可以运行这个查询:
exec sp_blitzindex @tablename='MyTable'
它将返回关于表的所有信息:
索引及其使用统计信息(读、写、锁等)、空间 二手和其他 缺失索引 列 外键 统计内容
当然,它不是一个系统,也不像sp_help或sp_columns那样通用,但它返回关于表的所有可能信息,我认为值得在您的环境中创建它并在这里提到它。
请使用以下sql查询;这对我的案子很管用。
select * FROM INFORMATION_SCHEMA.Columns where table_name = 'tablename';
推荐文章
- 如何在Ruby On Rails中使用NuoDB手动执行SQL命令
- 查询JSON类型内的数组元素
- 确定记录是否存在的最快方法
- 获得PostgreSQL数据库中当前连接数的正确查询
- 在SQL选择语句Order By 1的目的是什么?
- 从现有模式生成表关系图(SQL Server)
- 我如何循环通过一组记录在SQL Server?
- 数据库和模式的区别
- 如何在SQL Server中一次更改多个列
- 如何从命令行通过mysql运行一个查询?
- 外键约束可能导致循环或多条级联路径?
- 使用LIMIT/OFFSET运行查询,还可以获得总行数
- 当恢复sql时,psql无效命令\N
- 货币应该使用哪种数据类型?
- 如何选择每一行的列值不是独特的