¿Cuál es la mejor manera de obtener los nombres de todas las tablas de una base de datos específica en SQL Server?
SQL Server 2005, 2008, 2012, 2014, 2016, 2017 o 2019:
SELECT * FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_TYPE='BASE TABLE'
Para mostrar sólo las tablas de una base de datos en particular
SELECT TABLE_NAME
FROM <DATABASE_NAME>.INFORMATION_SCHEMA.TABLES
WHERE TABLE_TYPE = 'BASE TABLE'
O,
SELECT TABLE_NAME
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_TYPE = 'BASE TABLE'
AND TABLE_CATALOG='dbName' --(for MySql, use: TABLE_SCHEMA='dbName' )
P.D: Para SQL Server 2000:
SELECT * FROM sysobjects WHERE xtype='U'
SELECT sobjects.name
FROM sysobjects sobjects
WHERE sobjects.xtype = 'U'
Aquí hay una lista de otros tipos de objetos que también puedes buscar:
SELECT * FROM INFORMATION_SCHEMA.TABLES
o
SELECT * FROM Sys.Tables
USE YourDBName
GO
SELECT *
FROM sys.Tables
GO
O
USE YourDBName
GO
SELECT * FROM INFORMATION_SCHEMA.TABLES
GO
La desventaja de "INFORMATION_SCHEMA.TABLES" es que también incluye tablas de sistema como "propiedades" y las tablas "MSPEER", sin forma de distinguirlas de las tuyas.
Recomendaría usar [sys.objects
][1] (la nueva versión de la obsoleta vista [sysobjects][2]), que sí soporta la exclusión de las tablas de sistema:
select *
from sys.objects
where type = 'U' -- User tables
and is_ms_shipped = 0 -- Exclude system tables
[1]: https://docs.microsoft.com/en-us/sql/relational-databases/system-catalog-views/sys-objects-transact-sql [2]: https://docs.microsoft.com/en-us/sql/relational-databases/system-compatibility-views/sys-sysobjects-transact-sql
En el SSMS, para obtener todos los nombres de tablas completamente calificados en una base de datos específica (por ejemplo, "MiBase de Datos"):
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:
Por favor, use esto. Obtendrá los nombres de las tablas junto con los nombres de los esquemas:
SELECT SYSSCHEMA.NAME, SYSTABLE.NAME
FROM SYS.tables SYSTABLE
INNER JOIN SYS.SCHEMAS SYSSCHEMA
ON SYSTABLE.SCHEMA_ID = SYSSCHEMA.SCHEMA_ID
Bueno, puedes usar... objetos del sistema..; para obtener todos los objetos de la base de datos.
GO
select * from sys.objects where type_desc='USER_TABLE' order by name
GO
O
-- 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
puedes simplemente seleccionar tu base de datos primero
use database_name;
entonces sólo tienes que escribir
show tables;
Gracias a Ray Vega, cuya respuesta da todas las tablas de usuarios en una base de datos...
...de los usuarios en una base de datos; exec sp_msforeachtable 'print ''?''''
sp_helptext muestra la consulta subyacente, que resume...
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
--for oracle
select tablespace_name, table_name from all_tables;
Este enlace puede proporcionar mucha más información sobre este [tema][1]