获取表信息

时间:2011-10-07 15:47:40

标签: sql-server tsql sql-server-2008 sysobjects

我试图让表信息给出一个表名,所以我写了一个这样的查询:

 SELECT so.name, sc.name, st.name, sc.length, CASE WHEN sc.status = 0x80 THEN 'Y' ELSE 'N' END AS IsIdent, ColOrder
   FROM Asdim.dbo.sysobjects so
   INNER JOIN Asdim.dbo.syscolumns sc
   ON so.id=  sc.id
   INNER JOIN Asdim.dbo.systypes st
   ON sc.xtype = st.xusertype
   WHERE so.Name = 'Admin'

问题是我有两个名为'Admin'的表,但它们有不同的模式。所以当我运行这个查询时:

SELECT * FROM Asdim.dbo.sysobjects WHERE name LIKE 'Admin'

由于表名相同,我得到两条记录。有没有办法根据模式名称过滤出来?

1 个答案:

答案 0 :(得分:1)

您正在使用的视图都已弃用,只是为了向后兼容而提供。使用新视图可以得到。

SELECT t.name,
       c.name,
       ty.name,
       c.is_identity,
       c.max_length,
       c.column_id
FROM sys.tables t
JOIN sys.schemas s ON s.schema_id=t.schema_id
JOIN sys.columns c ON c.object_id = t.object_id
JOIN sys.types ty ON ty.user_type_id = c.user_type_id
WHERE t.name LIKE '%Admin%' AND s.name = 'dbo'

INFORMATION_SCHEMA.COLUMNS提供了您需要的几乎所有信息,但缺少有关标识列的信息。