我有一个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视图将为您提供所需的信息,但不幸的是,您必须手动查询这些视图并连接它们。
如果你正在使用Brent Ozar团队的FirstResponderKit,你也可以运行这个查询:
exec sp_blitzindex @tablename='MyTable'
它将返回关于表的所有信息:
索引及其使用统计信息(读、写、锁等)、空间 二手和其他 缺失索引 列 外键 统计内容
当然,它不是一个系统,也不像sp_help或sp_columns那样通用,但它返回关于表的所有可能信息,我认为值得在您的环境中创建它并在这里提到它。
您可以使用以下方法:sp_help表名
[示例]sp_help客户
或使用快捷键
选择所需的表并按ALT+F1。
示例:客户按“ALT+F1”。
你可以使用sp_columns存储过程:
exec sp_columns MyTable
SQL Server中与Oracle的describe命令等价的是存储的proc sp_help
describe命令提供了列名、类型、长度等信息。
在SQL Server中,假设你想在数据库'mydb'中的模式'myschema'中描述一个表'mytable',你可以这样做:
USE mydb;
exec sp_help 'myschema.mytable';
推荐文章
- 在SQL Server 2008 R2中重命名数据库时出错
- 将数据复制到另一个表中
- 如何在SQL中选择表的最后一条记录?
- SQL在Oracle中连接多行列值的查询
- 修改列,添加默认约束
- 在单个查询中计算空值和非空值
- 在存储过程中使用“SET XACT_ABORT ON”有什么好处?
- SQL to LINQ工具
- 如何从一个查询插入多行使用雄辩/流利
- 如何连接列在Postgres选择?
- 有人可以对SQL查询进行版权保护吗?
- 如何知道MySQL表最近一次更新?
- 如何转储一些SQLite3表的数据?
- 如何检查SQL Server文本列是否为空?
- 如何创建一个SQL Server函数“连接”多行从一个子查询到一个单独的分隔字段?