2010-03-25 11 views

Antwort

8

Hier ist, was Sie gefragt:

select 
    s.name as [Schema], 
    o.type_desc as [Type], 
    o.name as [Name] 
from 
    sys.all_objects o 
    inner join sys.schemas s on s.schema_id = o.schema_id 
where 
    o.type in ('U', 'V', 'P') -- tables, views, and stored procedures 
order by 
    s.name 
0

Start mit

select * from sys.sysobjects 

EDIT: Jetzt mit Schema

select * from sys.sysobjects 
inner join sys.schemas on sys.sysobjects.uid = sys.schemas.schema_id 
1

Sie können eine Abfrage unter Verwendung der Systemansichten erstellen INFORMATION_SCHEMA.TABLES, INFORMATION_SCHEMA.VIEWS und INFORMATION_SCHEMA.COLUMNS

Edit: Ach ja, und INFORMATION_SCHEMA.ROUTINES für gespeicherte Procs

0

Es sind, können einige eingebaute Systemansichten, die Sie verwenden:

  • sys.views
  • sys.tables
  • sys.procedures
  • sys.schema

Mehr Informationen über MSDN über Catalog Views.

0

TRY:

SELECT 
    ROUTINE_SCHEMA,ROUTINE_TYPE ,ROUTINE_NAME 
    FROM INFORMATION_SCHEMA.ROUTINES 
UNION 
SELECT 
    TABLE_SCHEMA,TABLE_TYPE,TABLE_NAME 
    FROM INFORMATION_SCHEMA.TABLES 
UNION 
SELECT 
    TABLE_SCHEMA,'VIEW' ,TABLE_NAME 
    FROM INFORMATION_SCHEMA.VIEWS 
    ORDER BY ROUTINE_SCHEMA,ROUTINE_TYPE ,ROUTINE_NAME 
0

diese SQL-Versuchen, wenn Sie auch in Spalten und ihre Daten eingeben, um graben müssen. Sie können diese Optionen für sysobjects.xtype (U = Benutzertabelle, P = Stored Proc, V = Ansicht)

SELECT object_type = sysobjects.xtype, 
    table_name = sysobjects.name, 
    column_name = syscolumns.name, 
    datatype = systypes.name, 
    length = syscolumns.length 
FROM sysobjects 
JOIN syscolumns ON sysobjects.id = syscolumns.id 
JOIN systypes ON syscolumns.xtype=systypes.xtype 
    WHERE sysobjects.xtype='U' AND 
syscolumns.name LIKE '%[column_name_here]%' 
AND sysobjects.name LIKE '%[table or Stored Proc Name]%' 
ORDER BY sysobjects.name,syscolumns.colid 
0

Dies ist die SQL-Anweisung I am Ende mit verwenden:

SELECT 
     CASE so.type 
      WHEN 'U' THEN 'table' 
      WHEN 'P' THEN 'stored proc' 
      WHEN 'V' THEN 'view' 
     END AS [type], 
     s.name AS [schema], 
     so.[name] AS [name] 
FROM sys.sysobjects so 
JOIN sys.schemas s 
ON so.uid = s.schema_id 
WHERE so.type IN ('U', 'P', 'V') 
ORDER BY [type], [schema], [name] asc 
Verwandte Themen