Jak uzyskać listę wszystkich tabel w bazie danych przy użyciu TSQL?

Jaki jest najlepszy sposób na uzyskanie nazw wszystkich tabel w określonej bazie danych na serwerze SQL?

Author: Christopher Rapcewicz, 2008-10-06

17 answers

SQL Server 2000, 2005, 2008, 2012, 2014, 2016, 2017 lub 2019:

SELECT * FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_TYPE='BASE TABLE'

Aby wyświetlać tylko tabele z konkretnej 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' 
 1494
Author: ScottStonehouse,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2020-10-01 13:29:36
SELECT sobjects.name
FROM sysobjects sobjects
WHERE sobjects.xtype = 'U'

Oto lista innych typów obiektów, które możesz również wyszukać:

  • AF: funkcja agregująca (CLR)
  • C: ograniczenie kontrolne
  • D: default lub default constraint
  • F: ograniczenie klucza obcego
  • L: Log
  • FN: funkcja skalarna
  • FS: Assembly (CLR) scalar-function
  • FT: Assembly (CLR) table-valued function
  • IF: in-lined table-function
  • IT: tablica wewnętrzna
  • P: procedura składowana
  • PC: montaż (CLR) stored-procedure
  • PK: ograniczenie klucza głównego (Typ to K)
  • RF: replication filter stored procedure
  • S: tabela systemowa
  • SN: synonim
  • SQ: Kolejka usług
  • TA: Assembly (CLR) DML trigger
  • TF: Funkcja Tabeli
  • TR: SQL DML Trigger
  • TT: Typ Tabeli
  • U: User table
  • UQ: unique constraint (type is K)
  • V: Widok
  • X: rozszerzona procedura składowana
 200
Author: Micah,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2015-10-27 18:10:32
SELECT * FROM INFORMATION_SCHEMA.TABLES 

Lub

SELECT * FROM Sys.Tables
 91
Author: StingyJack,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2020-04-19 17:14:23
USE YourDBName
GO 
SELECT *
FROM sys.Tables
GO

Lub

USE YourDBName
GO
SELECT * FROM INFORMATION_SCHEMA.TABLES 
GO
 30
Author: Vikash Singh,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2019-01-29 02:03:26
SELECT * FROM information_schema.tables
where TABLE_TYPE = 'BASE TABLE'

SQL Server 2012

 11
Author: Rasoul Zabihi,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2013-08-13 07:45:56
exec sp_msforeachtable 'print ''?'''
 9
Author: Ray,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2008-10-06 17:53:54
SELECT name 
FROM sysobjects 
WHERE xtype='U' 
ORDER BY name;

(SQL Server 2000 standard; nadal wspierany w SQL Server 2005.)

 9
Author: devio,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2012-03-15 02:21:17

select * from sysobjects where xtype='U'

 8
Author: spoulson,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2008-10-06 17:55:21
SELECT sobjects.name
FROM sysobjects sobjects
WHERE sobjects.xtype = 'U' 
 6
Author: Erikk Ross,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2008-10-06 17:56:33

Minusem INFORMATION_SCHEMA.TABLES jest to, że zawiera również tabele systemowe, takie jak dtproperties i tabele MSpeer_..., bez możliwości odróżnienia ich od własnych tabel.

Polecam użycie sys.objects (nowa wersja przestarzałego widokusysobjects), który obsługuje wyłączanie tabel systemowych:

select *
from sys.objects
where type = 'U'      -- User tables
and is_ms_shipped = 0 -- Exclude system tables
 5
Author: Astrotrain,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2017-09-27 12:20:24
--for oracle
select tablespace_name, table_name from all_tables;

TEN link może dostarczyć znacznie więcej informacji na ten temat Temat

 2
Author: Demietra95,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2015-11-13 12:34:51

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:

  • MyDatabase.dbo.MyTable1
  • MyDatabase.dbo.MyTable2
  • MyDatabase.MySchema.MyTable3
  • MyDatabase.MySchema.MyTable4
  • itd.
 2
Author: Scott Software,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2017-10-13 03:10:09

Proszę użyć tego. Otrzymasz nazwy tabel wraz z nazwami schematów:

SELECT SYSSCHEMA.NAME, SYSTABLE.NAME
FROM SYS.tables SYSTABLE
INNER JOIN SYS.SCHEMAS SYSSCHEMA
ON SYSTABLE.SCHEMA_ID = SYSSCHEMA.SCHEMA_ID
 2
Author: Vikash,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2018-05-07 12:08:44

Cóż możesz użyć sys.objects Aby pobrać 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
 2
Author: DarkRob,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2019-02-16 09:00:55
SELECT TABLE_NAME 
FROM INFORMATION_SCHEMA.TABLES 
WHERE TABLE_TYPE='BASE TABLE' 
ORDER BY TABLE_NAME
 1
Author: DmitryBoyko,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2017-07-07 04:35:54

Dzięki Rayowi Vegi, którego odpowiedź daje wszystkie tabele użytkownika w bazie danych...

Exec sp_msforeachtable 'print'?'''

Sp_helptext pokazuje podstawowe 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 
 1
Author: Frank,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2017-08-17 22:19:04

Użycie SELECT * FROM INFORMATION_SCHEMA.COLUMNS pokazuje również wszystkie tabele i powiązane kolumny.

 1
Author: Masoud Darvishian,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2019-01-07 07:43:50