SQL Server上の特定のデータベースにあるすべてのテーブルの名前を取得する最良の方法は何ですか?
SHOW TABLES
(MySQLの中で使用されるような)仕事?
SQL Server上の特定のデータベースにあるすべてのテーブルの名前を取得する最良の方法は何ですか?
SHOW TABLES
(MySQLの中で使用されるような)仕事?
回答:
SQL Server 2000、2005、2008、2012、2014、2016、2017または2019:
SELECT * FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_TYPE='BASE TABLE'
特定のデータベースのテーブルのみを表示するには
SELECT TABLE_NAME
FROM <DATABASE_NAME>.INFORMATION_SCHEMA.TABLES
WHERE TABLE_TYPE = 'BASE TABLE'
または、
SELECT TABLE_NAME
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_TYPE = 'BASE TABLE'
AND TABLE_CATALOG='dbName' --(for MySql, use: TABLE_SCHEMA='dbName' )
PS:SQL Server 2000の場合:
SELECT * FROM sysobjects WHERE xtype='U'
WHERE TABLE_TYPE='BASE TABLE'
と、ベーステーブルのみが含まれます(拡張機能を使用すると、常にを使用できますWHERE TABLE_TYPE != 'VIEW'
)。
AND name <> 'sysdiagrams'
ます。
SELECT sobjects.name
FROM sysobjects sobjects
WHERE sobjects.xtype = 'U'
検索可能な他のオブジェクトタイプのリストを次に示します。
SELECT name FROM sysobjects WHERE xtype = 'U'
同じことをします。
'U'
ユーザーテーブルの識別になぜ使用されているのか不思議に思うかもしれませんが'UT'
、多分、または最も直感的な方法とは対照的に'T'
...ああ、これでうまくいきます!
の欠点はINFORMATION_SCHEMA.TABLES
、dtproperties
やテーブルなどのシステムテーブルも含まれており、MSpeer_...
独自のテーブルと区別する方法がないことです。
システムテーブルの除外をサポートsys.objects
する(非推奨のsysobjectsビューの新しいバージョン) を使用することをお勧めします。
select *
from sys.objects
where type = 'U' -- User tables
and is_ms_shipped = 0 -- Exclude system tables
SSMSで、特定のデータベース(たとえば、「MyDatabase」)内のすべての完全修飾テーブル名を取得するには:
SELECT [TABLE_CATALOG] + '.' + [TABLE_SCHEMA] + '.' + [TABLE_NAME]
FROM MyDatabase.INFORMATION_SCHEMA.Tables
WHERE [TABLE_TYPE] = 'BASE TABLE' and [TABLE_NAME] <> 'sysdiagrams'
ORDER BY [TABLE_SCHEMA], [TABLE_NAME]
結果:
sys.objectsを使用して、すべてのデータベースオブジェクトを取得できます。
GO
select * from sys.objects where type_desc='USER_TABLE' order by name
GO
または
-- For all tables
select * from INFORMATION_SCHEMA.TABLES
GO
--- For user defined tables
select * from INFORMATION_SCHEMA.TABLES where TABLE_TYPE='BASE TABLE'
GO
--- For Views
select * from INFORMATION_SCHEMA.TABLES where TABLE_TYPE='VIEW'
GO
を使用SELECT * FROM INFORMATION_SCHEMA.COLUMNS
すると、すべてのテーブルと関連する列も表示されます。