大家好我是jdbc的新手,我想知道是否有办法检查mysql中是否已经存在某个特定的数据库.
假设我想创建一个名为students的数据库,如果学生数据库已经在mysql中创建,eclipse中的错误消息会说明这个学生数据库已经存在.但是我想要做的是创建一个布尔方法来检查学生数据库是否已经存在.如果它存在,那么布尔方法将返回false,否则它是真的然后我可以创建学生数据库.我如何用Java做这些?在jdbc中是否有任何方法可以执行此操作,还是需要从头开始编写代码?谢谢你的帮助.
我遵循了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;
}
Run Code Online (Sandbox Code Playgroud)
mgu*_*mon 18
您可以使用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();
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
25608 次 |
| 最近记录: |