Как получить список всех таблиц в базе данных, используя TSQL?

895

Каков наилучший способ получить имена всех таблиц в конкретной базе данных на SQL Server?

луч
источник
3
Работает ли SHOW TABLES(как используется в MySQL)?
Мартин Тома

Ответы:

1429

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' 
ScottStonehouse
источник
46
Обратите внимание, что это также будет включать в себя VIEWS, а не только таблицы
Натан Куп
17
Добавьте имя базы данных, если вы не используете конкретную базу данных, так что это будет SELECT TABLE_NAME FROM <DATABASE_NAME> .INFORMATION_SCHEMA.Tables
Shriroop
22
Добавление WHERE TABLE_TYPE='BASE TABLE'будет включать только базовые таблицы (и по расширению вы всегда можете использовать WHERE TABLE_TYPE != 'VIEW').
Филипп Копли
3
"sysdiagrams" также появляется в этом списке :(
celsowm
4
sysdiagrams - это обычная таблица, вы всегда должны исключать ее вручную с помощью AND name <> 'sysdiagrams'.
Кристоф
199
SELECT sobjects.name
FROM sysobjects sobjects
WHERE sobjects.xtype = 'U'

Вот список других типов объектов, которые вы также можете искать:

  • AF: Агрегатная функция (CLR)
  • C: ПРОВЕРЬТЕ ограничение
  • D: ограничение по умолчанию или DEFAULT
  • F: ограничение КЛЮЧЕВОЙ КЛЮЧ
  • L: Журнал
  • FN: скалярная функция
  • Скалярная функция FS: Assembly (CLR)
  • FT: Сборочная (CLR) табличная функция
  • IF: встроенная табличная функция
  • IT: внутренний стол
  • P: хранимая процедура
  • ПК: сборка (CLR) хранимая процедура
  • PK: ограничение PRIMARY KEY (тип K)
  • RF: хранимая процедура фильтра репликации
  • S: Системная таблица
  • SN: Синоним
  • SQ: очередь обслуживания
  • TA: сборка (CLR) DML-триггер
  • TF: табличная функция
  • TR: SQL DML Trigger
  • TT: тип таблицы
  • U: таблица пользователей
  • UQ: УНИКАЛЬНОЕ ограничение (тип K)
  • V: Просмотр
  • X: расширенная хранимая процедура
Михей
источник
9
Псевдоним немного избыточен: SELECT name FROM sysobjects WHERE xtype = 'U'будет делать то же самое.
ПАОПеленд
Спасибо, сначала я попробовал это с несколькими операторами выбора для и PK,FK,D,C,V,UQт. Д., Чтобы сравнить исходную и целевую базу данных, но затем я нашел эту функцию в VS, но разве нет sql queryвозможности сравнить полную исходную и целевую базу данных?
Shaijut
Вы задаетесь вопросом, почему 'U'используется для идентификации таблицы пользователей ... в отличие от, может быть, 'UT'или, наиболее интуитивно, 'T'... Ах, ну, это работает!
user919426
87
SELECT * FROM INFORMATION_SCHEMA.TABLES 

ИЛИ

SELECT * FROM Sys.Tables
StingyJack
источник
5
Просто обратите внимание, что (как упоминалось в других ответах) sys.tables доступен только в 2005 году
Роб
2
Что не является проблемой в 2018 году. Я думаю, что это должно быть выше :-)
Михал Б.
29
USE YourDBName
GO 
SELECT *
FROM sys.Tables
GO

ИЛИ

USE YourDBName
GO
SELECT * FROM INFORMATION_SCHEMA.TABLES 
GO
Викаш Сингх
источник
11
SELECT * FROM information_schema.tables
where TABLE_TYPE = 'BASE TABLE'

SQL Server 2012

Расул Забихи
источник
9
SELECT name 
FROM sysobjects 
WHERE xtype='U' 
ORDER BY name;

(Стандарт SQL Server 2000; все еще поддерживается в SQL Server 2005.)

devio
источник
6
SELECT sobjects.name
FROM sysobjects sobjects
WHERE sobjects.xtype = 'U' 
Эрикк Росс
источник
SELECT name FROM sysobjects WHERE xtype='U' AND name <> 'sysdiagrams'; потому что таблица системных диаграмм, хотя и создается Microsoft SQL Server Management Studio, технически не системная таблица, а та, которую мы обычно предпочитаем исключать.
Кристоф
5

Недостатком 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
Астропоезд
источник
2

В 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]

Результаты:

  • MyDatabase.dbo.MyTable1
  • MyDatabase.dbo.MyTable2
  • MyDatabase.MySchema.MyTable3
  • MyDatabase.MySchema.MyTable4
  • и т.п.
Скотт Программное обеспечение
источник
2

Пожалуйста, используйте это. Вы получите имена таблиц вместе с именами схем:

SELECT SYSSCHEMA.NAME, SYSTABLE.NAME
FROM SYS.tables SYSTABLE
INNER JOIN SYS.SCHEMAS SYSSCHEMA
ON SYSTABLE.SCHEMA_ID = SYSSCHEMA.SCHEMA_ID
Vikash
источник
1
SELECT TABLE_NAME 
FROM INFORMATION_SCHEMA.TABLES 
WHERE TABLE_TYPE='BASE TABLE' 
ORDER BY TABLE_NAME
разработчик
источник
1

Спасибо Рэю Веге, чей ответ дает все пользовательские таблицы в базе данных ...

exec sp_msforeachtable 'print' '?' ''

sp_helptext показывает основной запрос, который сводится к ...

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

Ну, вы можете использовать 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
DarkRob
источник
0
--for oracle
select tablespace_name, table_name from all_tables;

Эта ссылка может предоставить гораздо больше информации по этой теме

Demietra95
источник
2
Это не для SQL Server, поэтому не является ответом на этот вопрос.
Дэн Гетц
0

Использование SELECT * FROM INFORMATION_SCHEMA.COLUMNSтакже показывает все таблицы и связанные столбцы.

Масуд Дарвишян
источник