以下是使用`INFORMATION_SCHEMA.COLUMNS`查询特定表的字段名的基本语法:
```sql
SELECT COLUMN_NAME
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_NAME = N'YourTableName'
AND TABLE_SCHEMA = N'YourSchemaName'; -- 默认是dbo,如果你的表位于其他架构,请相应修改
```
将`YourTableName`替换为你想要查询的表名,并且确保`TABLE_SCHEMA`匹配该表所在的架构(如果不确定,通常架构名为`dbo`)。
示例
假设你有一个名为`Employees`的表,在默认的`dbo`架构下,你可以这样查询它的字段名:
```sql
SELECT COLUMN_NAME
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_NAME = N'Employees'
AND TABLE_SCHEMA = N'dbo';
```
此查询会返回`Employees`表的所有列名。
其他方法
除了`INFORMATION_SCHEMA.COLUMNS`外,还有其他几种方式可以获取表的字段信息。
1. 使用`sys.columns`和`sys.tables`:
```sql
SELECT c.name AS ColumnName
FROM sys.columns c
JOIN sys.tables t ON c.object_id = t.object_id
WHERE t.name = 'YourTableName'
AND t.schema_id = SCHEMA_ID('YourSchemaName');
```
2. 使用`sp_columns`存储过程:
```sql
EXEC sp_columns @table_name = 'YourTableName', @table_owner = 'YourSchemaName';
```
在实际使用时,根据你对输出内容的需求选择最适合的方法。`INFORMATION_SCHEMA.COLUMNS`提供了一个标准化的方式来查询字段信息,而`sys.columns`和`sp_columns`则可能提供更多SQL Server特有的细节信息。