我如何返回一个表的列名使用SQL Server 2008?即一个表包含这些列- id,名称,地址,国家,我想返回这些数据。


当前回答

SELECT *
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_NAME = N'TableName'

其他回答

我不确定syscolumns。colid值与作为sp_columns一部分返回的'ORDINAL_POSITION'值相同,但在接下来的内容中,我将以这种方式使用它-希望我没有误导…

这是我发现的一些其他答案的轻微变化-我使用这个是因为表中列的“位置”或顺序在我的应用程序中很重要-我基本上需要知道“列(n)被称为什么?”

sp_columns返回一大堆无关的东西,我使用select函数比T-SQL函数更方便,所以我走了这条路:

select    
  syscolumns.name, 
  syscolumns.colid    
from     
  sysobjects, syscolumns  
where 
  sysobjects.id = syscolumns.id and   
  sysobjects.xtype = 'u' and   
  sysobjects.name = '<YOUR_TABLE>' 
order by syscolumns.colid 

我使用

SELECT st.NAME, sc.NAME, sc.system_type_id
FROM sys.tables st
INNER JOIN sys.columns sc ON st.object_id = sc.object_id
WHERE st.name LIKE '%Tablename%'

像这样的东西?

sp_columns @table_name=your table name

如果你正在使用postgresql,有可能不止一个模式有相同名称的表,在这种情况下应用下面的查询

SELECT column_name, data_type 
FROM information_schema.columns
WHERE table_name = 'your_table_name' AND table_schema = 'your_schema_name’;

虽然@Gulzar Nazim的回答很好,但在查询中包含数据库名称可能更容易,这可以通过下面的SQL实现。

SELECT COLUMN_NAME, *
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_NAME = 'you-table-name' AND TABLE_CATALOG='your-database-name'