如何使用java检查mysql中的特定数据库是否已经存在

lp0sw83n  于 2023-01-24  发布在  Java
关注(0)|答案(5)|浏览(325)

我是JDBC的新手,我想看看是否有一种方法可以检查MySQL中是否已经存在某个特定的数据库。
假设我想创建一个名为students的数据库,如果已经在MySQL中创建了学生数据库,Eclipse中的错误消息会指出这个学生数据库已经存在。但是我想做的是创建一个布尔方法来检查学生数据库是否已经存在。如果它存在,那么布尔方法将返回false,否则返回true,那么我可以创建学生数据库。我如何在Java中做这些呢?JDBC中是否有任何方法可以做到这一点,或者我需要从头开始编写代码?

编辑2

我听从了mguymons的建议这就是我的想法

public boolean checkDBExists(String dbName){

    try {
        Class.forName(JDBCDriver); //Register JDBC Driver
        
        System.out.println("Creating a connection...");
        conn = DriverManager.getConnection(DBURL, USER, PASS); //Open a connection
    
        ResultSet resultSet = conn.getMetaData().getCatalogs();
        
        while (resultSet.next()) {
        
          String databaseName = resultSet.getString(1);
            if(databaseName.equals(dbName)){
                return true;
            }
        }
        resultSet.close();

    }
    catch(Exception e){
        e.printStackTrace();
    }
    
    return false;
}
mqkwyuun

mqkwyuun1#

您可以使用DatabaseMetaData#getCatalogs从 *JDBC连接 * 获取该信息,下面是获取目录(即数据库名称)的示例

// Connection connection = <your java.sql.Connection>
ResultSet resultSet = connection.getMetaData().getCatalogs();

//iterate each catalog in the ResultSet
while (resultSet.next()) {
  // Get the database name, which is at position 1
  String databaseName = resultSet.getString(1);
}
resultSet.close();
kxe2p93d

kxe2p93d2#

show databases like 'students'

如果返回一行,则它存在。

d5vmydt9

d5vmydt93#

在较新版本的MySQL(5及以上版本)中运行以下查询:

SELECT COUNT(*)
FROM information_schema.tables 
WHERE table_schema = '[database name]' 
AND table_name = '[table name]';

如果结果为1,则存在。
在Java JDBC中,它看起来像这样:

// Create connection and statement
String query = "SELECT COUNT(*) FROM information_schema.tables WHERE table_schema'[database name]' AND table_name = '[table name]'";
ResultSet rs = stmt.executeQuery(query);                  
rs.next();
boolean exists = rs.getInt("COUNT(*)") > 0;
// Close connection, statement, and result set.
return exists;
lyfkaqu1

lyfkaqu14#

你是从后往前做的,正确的方法是尝试创建它并捕获异常,你想要做的方法会受到时间窗口问题的影响:当你测试的时候它不在那里,但是当你试图创建它的时候它就在那里了,而且你仍然需要捕捉异常。

m2xkgtsf

m2xkgtsf5#

一旦找到了目标数据库,你就应该跳出循环,否则,只有你的目标搜索是结果集中的最后一个才有意义。
公共布尔检查DBExists(字符串dbName){

try {
    Class.forName(JDBCDriver); //Register JDBC Driver
    
    System.out.println("Creating a connection...");
    conn = DriverManager.getConnection(DBURL, USER, PASS); //Open a connection

    ResultSet resultSet = conn.getMetaData().getCatalogs();
    
    while (resultSet.next()) {
    
      String databaseName = resultSet.getString(1);
        if(databaseName.equals(dbName)){
            return true;
            break;
        }
    }
    resultSet.close();

}
catch(Exception e){
    e.printStackTrace();
}

return false;

}

相关问题