14

私はJDBCを初めて使用し、特定のデータベースがMySQLにすでに存在するかどうかを確認する方法があるかどうかを知りたいと思いました。

学生という名前のデータベースを作成したいとします。学生データベースが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;
}
4

4 に答える 4

21

DatabaseMetaData#g​​etCatalogsを使用して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();
于 2012-09-13T21:04:09.527 に答える
8
show databases like 'students'

行が返された場合、それは存在します。

于 2012-09-13T20:54:24.933 に答える
3

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;   
于 2012-09-13T20:56:08.853 に答える
2

あなたはそれを後ろから前にやっています。正しいテクニックは、それを作成して例外をキャッチしようとすることです。あなたがそれをしたい方法はタイミングウィンドウの問題の影響を受けます:あなたがそれをテストしたときそれはそこにありませんでした、しかしあなたがそれを作成しようとしたときそれはそこにありました。そして、とにかく例外をキャッチする必要があります。

于 2012-09-13T22:07:24.743 に答える