如何使用JDBC获取所有数据库的列表?
您可以使用SHOWDATABASES查询获取MySQL中的数据库列表。
show databases;
以下JDBC程序通过执行showdatabase查询来检索数据库列表。
示例
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;
public class ShowDatabasesExample {
public static void main(String args[]) throws Exception {
//注册驱动程序
DriverManager.registerDriver(new com.mysql.jdbc.Driver());
//获得连接
String mysqlUrl = "jdbc:mysql://localhost/mydatabase";
Connection con = DriverManager.getConnection(mysqlUrl, "root", "password");
System.out.println("Connection established......");
//创建一个Statement对象
Statement stmt = con.createStatement();
//检索数据
ResultSet rs = stmt.executeQuery("Show Databases");
System.out.println("List of databases: ");
while(rs.next()) {
System.out.print(rs.getString(1));
System.out.println();
}
}
}输出结果
Connection established...... List of databases: information_schema base details errors logging mydatabase mydb mysql performance_schema sample_database sampledb students sys testdb world
或者,您可以使用DatabaseMetaData接口的getCatalogs()方法。
示例
import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.DriverManager;
import java.sql.ResultSet;
public class ListOfAllDatabases {
public static void main(String args[]) throws Exception {
//注册驱动程序
DriverManager.registerDriver(new com.mysql.jdbc.Driver());
//获得连接
String mysqlUrl = "jdbc:mysql://localhost/mydatabase";
Connection con = DriverManager.getConnection(mysqlUrl, "root", "password");
System.out.println("Connection established......");
//检索元数据对象
DatabaseMetaData metaData = con.getMetaData();
//检索数据库名称列表
ResultSet tables = metaData.getCatalogs();
while (tables.next()) {
System.out.println(tables.getString("TABLE_CAT"));
}
}
}输出结果
Connection established...... List of databases: information_schema base details errors logging mydatabase mydb mysql performance_schema sample_database sampledb students sys testdb world
热门推荐
10 香港老妈结婚祝福语简短
11 毕业立体贺卡祝福语简短
12 简短新年年会祝福语
13 评论小品祝福语大全简短
14 恭喜师兄结婚祝福语简短
15 员工集体辞职祝福语简短
16 高中新生祝福语 简短
17 装修祝福语男生搞笑简短
18 生日开业蛋糕祝福语简短