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

我是JDBC的新手,我想找出是否有一种方法可以检查MySQL中是否已经存在特定的数据库

假设我想创建一个名为students的数据库,如果已经在MySQL中创建了students数据库,则eclipse中的错误消息将指出该students数据库已经存在。但是,我想做的是创建一个布尔方法来检查学生数据库是否已经存在。如果存在,则布尔方法将返回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;

}

回答:

您可以使用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();

以上是 如何使用Java检查mysql中的特定数据库是否已经存在 的全部内容, 来源链接: utcz.com/qa/421090.html

回到顶部