我正在工作的应用程序,可以处理多个数据库服务器,如“MySQL”和“MS SQL Server”。
我想获得表的名称使用一个通用的查询,应该适合于所有数据库类型的特定数据库。我尝试了以下几点:
SELECT TABLE_NAME
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_TYPE='BASE TABLE'
但它是给表名的所有数据库的一个特定的服务器,但我想获得表名选择的数据库只。如何限制此查询以获取特定数据库的表?
我正在工作的应用程序,可以处理多个数据库服务器,如“MySQL”和“MS SQL Server”。
我想获得表的名称使用一个通用的查询,应该适合于所有数据库类型的特定数据库。我尝试了以下几点:
SELECT TABLE_NAME
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_TYPE='BASE TABLE'
但它是给表名的所有数据库的一个特定的服务器,但我想获得表名选择的数据库只。如何限制此查询以获取特定数据库的表?
当前回答
USE dbName;
SELECT TABLE_NAME
FROM INFORMATION_SCHEMA.TABLES
WHERE (TABLE_SCHEMA = 'dbName' OR TABLE_SCHEMA = 'schemaName')
ORDER BY TABLE_NAME
如果您在MS SQL server上使用多个模式,那么选择TABLE_NAME而不同时选择TABLE_SCHEMA的好处可能有限,因此我假设我们在使用MS SQL server时对属于已知模式的表感兴趣。
我已经用SQL Server Management Studio和MySQL Workbench分别用我自己的SQL Server数据库和MySQL数据库测试了上面的查询,在这两种情况下,它都给出了表名。
该查询将Michael Baylon的两个不同查询合并为一个,然后可以在任意一种数据库类型上运行。WHERE子句的第一部分适用于MySQL数据库,第二部分(在OR之后)适用于MS SQL Server数据库。它很难看,逻辑上也有点不正确,因为它假定不存在与数据库同名的不需要的模式。这可能会帮助那些正在寻找可以在任一数据库服务器上运行的单个查询的人。
其他回答
Exec sp_MSforeachtable 'Select ''?'''
根据Michael Baylon的回答,我需要一个包含模式信息的列表,这就是我修改他的查询的方式。
SELECT TABLE_SCHEMA + '.' + TABLE_NAME as 'Schema.Table'
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_TYPE = 'BASE TABLE' AND TABLE_CATALOG = 'dbName'
ORDER BY TABLE_SCHEMA, TABLE_NAME
SELECT TABLE_NAME
FROM your_database_name.INFORMATION_SCHEMA.TABLES
ORDER BY TABLE_NAME;
如果有人想在不使用"use"关键字的情况下列出特定数据库中的所有表:
SELECT TABLE_NAME FROM databasename.INFORMATION_SCHEMA.TABLES
可能是因为不同的sql dbms处理模式的方式不同。
试试下面的方法
对于SQL Server:
SELECT TABLE_NAME
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_TYPE = 'BASE TABLE' AND TABLE_CATALOG='dbName'
MySQL:
SELECT TABLE_NAME
FROM INFORMATION_SCHEMA.TABLES
WHERE TABLE_TYPE = 'BASE TABLE' AND TABLE_SCHEMA='dbName'
对于Oracle,我认为等效的方法是使用DBA_TABLES。