Каков наилучший способ получить имена всех таблиц в конкретной базе данных на 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'
... Ах, ну, это работает!
USE YourDBName
GO
SELECT *
FROM sys.Tables
GO
ИЛИ
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';
потому что таблица системных диаграмм, хотя и создается Microsoft SQL Server Management Studio, технически не системная таблица, а та, которую мы обычно предпочитаем исключать.
Недостатком 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]
Результаты:
SELECT TABLE_NAME
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_TYPE='BASE TABLE'
ORDER BY TABLE_NAME
Спасибо Рэю Веге, чей ответ дает все пользовательские таблицы в базе данных ...
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
Ну, вы можете использовать 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
также показывает все таблицы и связанные столбцы.