Jaki jest najlepszy sposób na uzyskanie nazw wszystkich tabel w określonej bazie danych na serwerze SQL Server?
SHOW TABLES
(jak używane w MySQL) działa?
Jaki jest najlepszy sposób na uzyskanie nazw wszystkich tabel w określonej bazie danych na serwerze SQL Server?
SHOW TABLES
(jak używane w MySQL) działa?
Odpowiedzi:
SQL Server 2000, 2005, 2008, 2012, 2014, 2016, 2017 lub 2019:
SELECT * FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_TYPE='BASE TABLE'
Aby wyświetlić tylko tabele z określonej bazy danych
SELECT TABLE_NAME
FROM <DATABASE_NAME>.INFORMATION_SCHEMA.TABLES
WHERE TABLE_TYPE = 'BASE TABLE'
Lub,
SELECT TABLE_NAME
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_TYPE = 'BASE TABLE'
AND TABLE_CATALOG='dbName' --(for MySql, use: TABLE_SCHEMA='dbName' )
PS: dla SQL Server 2000:
SELECT * FROM sysobjects WHERE xtype='U'
WHERE TABLE_TYPE='BASE TABLE'
obejmie tylko tabele podstawowe (a przez rozszerzenie możesz zawsze korzystać WHERE TABLE_TYPE != 'VIEW'
).
AND name <> 'sysdiagrams'
.
SELECT sobjects.name
FROM sysobjects sobjects
WHERE sobjects.xtype = 'U'
Oto lista innych typów obiektów, których możesz szukać:
SELECT name FROM sysobjects WHERE xtype = 'U'
zrobiłby to samo.
'U'
używa się go do identyfikacji tabeli użytkowników ... w przeciwieństwie do być może 'UT'
lub, najbardziej intuicyjnie, 'T'
... Ach, to działa!
SELECT * FROM INFORMATION_SCHEMA.TABLES
LUB
SELECT * FROM Sys.Tables
USE YourDBName
GO
SELECT *
FROM sys.Tables
GO
LUB
USE YourDBName
GO
SELECT * FROM INFORMATION_SCHEMA.TABLES
GO
SELECT * FROM information_schema.tables
where TABLE_TYPE = 'BASE TABLE'
SQL Server 2012
SELECT sobjects.name
FROM sysobjects sobjects
WHERE sobjects.xtype = 'U'
SELECT name FROM sysobjects WHERE xtype='U' AND name <> 'sysdiagrams';
ponieważ tabela sysdiagrams, choć utworzona przez Microsoft SQL Server Management Studio, technicznie nie jest tabelą systemową, ale taką, którą zwykle lubimy wykluczać.
Minusem INFORMATION_SCHEMA.TABLES
jest to, że zawiera również tabele systemowe, takie jak dtproperties
i MSpeer_...
tabele, bez możliwości odróżnienia ich od własnych tabel.
Polecam użycie sys.objects
(nowej wersji przestarzałego widoku sysobjects ), który obsługuje wykluczanie tabel systemowych:
select *
from sys.objects
where type = 'U' -- User tables
and is_ms_shipped = 0 -- Exclude system tables
W SSMS, aby uzyskać wszystkie w pełni kwalifikowane nazwy tabel w określonej bazie danych (np. „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]
Wyniki:
Dzięki Ray Vega, którego odpowiedź podaje wszystkie tabele użytkowników w bazie danych ...
exec sp_msforeachtable 'print' '?' '
sp_helptext pokazuje bazowe zapytanie, które podsumowuje do ...
select * from dbo.sysobjects o
join sys.all_objects syso on o.id = syso.object_id
where OBJECTPROPERTY(o.id, 'IsUserTable') = 1
and o.category & 2 = 0
Możesz użyć sys.objects, aby uzyskać wszystkie obiekty bazy danych.
GO
select * from sys.objects where type_desc='USER_TABLE' order by name
GO
LUB
-- 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
Używanie SELECT * FROM INFORMATION_SCHEMA.COLUMNS
pokazuje również wszystkie tabele i powiązane kolumny.