Qual é a melhor maneira de obter os nomes de todas as tabelas em um banco de dados específico no SQL Server?
SHOW TABLES
(como o usado no MySQL) trabalho?
Qual é a melhor maneira de obter os nomes de todas as tabelas em um banco de dados específico no SQL Server?
SHOW TABLES
(como o usado no MySQL) trabalho?
Respostas:
SQL Server 2000, 2005, 2008, 2012, 2014, 2016, 2017 ou 2019:
SELECT * FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_TYPE='BASE TABLE'
Para mostrar apenas tabelas de um banco de dados específico
SELECT TABLE_NAME
FROM <DATABASE_NAME>.INFORMATION_SCHEMA.TABLES
WHERE TABLE_TYPE = 'BASE TABLE'
Ou,
SELECT TABLE_NAME
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_TYPE = 'BASE TABLE'
AND TABLE_CATALOG='dbName' --(for MySql, use: TABLE_SCHEMA='dbName' )
PS: para SQL Server 2000:
SELECT * FROM sysobjects WHERE xtype='U'
WHERE TABLE_TYPE='BASE TABLE'
incluirá apenas tabelas base (e por extensão você sempre pode usar WHERE TABLE_TYPE != 'VIEW'
).
AND name <> 'sysdiagrams'
.
SELECT sobjects.name
FROM sysobjects sobjects
WHERE sobjects.xtype = 'U'
Aqui está uma lista de outros tipos de objetos que você também pode procurar:
SELECT name FROM sysobjects WHERE xtype = 'U'
faria a mesma coisa.
PK,FK,D,C,V,UQ
etc para comparar o banco de dados de origem e destino, mas então encontrei esse recurso no VS, mas não existe um sql query
para comparar o banco de dados completo de origem e destino?
'U'
é usado para identificar a Tabela de Usuários ... em vez de talvez 'UT'
ou, o mais intuitivo, 'T'
... Ah, bem, isso funciona!
USE YourDBName
GO
SELECT *
FROM sys.Tables
GO
OU
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';
porque a tabela sysdiagrams, embora criada pelo Microsoft SQL Server Management Studio, tecnicamente não é uma tabela do sistema, mas geralmente gostamos de excluir de qualquer maneira.
A desvantagem INFORMATION_SCHEMA.TABLES
disso é que ele também inclui tabelas de sistema como dtproperties
e as MSpeer_...
tabelas, sem nenhuma maneira de diferenciá-las de suas próprias tabelas.
Eu recomendaria usar sys.objects
(a nova versão da exibição de sysobjects obsoleta ), que suporta a exclusão das tabelas do sistema:
select *
from sys.objects
where type = 'U' -- User tables
and is_ms_shipped = 0 -- Exclude system tables
No SSMS, para obter todos os nomes de tabela totalmente qualificados em um banco de dados específico (por exemplo, "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]
Resultados:
SELECT TABLE_NAME
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_TYPE='BASE TABLE'
ORDER BY TABLE_NAME
Graças a Ray Vega, cuja resposta fornece todas as tabelas de usuários em um banco de dados ...
exec sp_msforeachtable 'print' '?' ''
sp_helptext mostra a consulta subjacente, resumida em ...
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
Bem, você pode usar sys.objects para obter todos os objetos de banco de dados.
GO
select * from sys.objects where type_desc='USER_TABLE' order by name
GO
OU
-- 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
O uso SELECT * FROM INFORMATION_SCHEMA.COLUMNS
também mostra todas as tabelas e colunas relacionadas.