Java不指定具体数据库名,建立Mysql连接

碰到个需求,即只提供IP地址,需要获取所有的数据库名,以及各个数据库的详细信息。

以下内容为转载,感谢作者。

本文是答疑文章

有朋友提出 为什么java建立连接 必须要指定数据库?不能像PHP那样连接数据库后再选择数据库吗?

答案是肯定的 能!

下面的例子 我建立连接的时候我并没有指定数据库,之后我使用“use db”选择了数据库,执行一样成功。

package com.cxy.jdbc;
 
import java.sql.Connection;
import java.sql.DriverManager;
import javax.sql.rowset.JdbcRowSet;
import com.sun.rowset.JdbcRowSetImpl;
 
/**
 * @author cxy
 */
public class ChooseDb
{
	public static void main(String[] args) throws Exception
	{
		Class.forName("com.mysql.jdbc.Driver");
		try
		(
				Connection con=DriverManager.getConnection("jdbc:mysql://localhost", "root", "root");
				JdbcRowSet jrs=new JdbcRowSetImpl(con);  
		)
		{
			jrs.setCommand("use dbtest"); //执行选择数据库操作
			jrs.execute();
			jrs.setCommand("select * from t_student");
			jrs.execute();
			System.out.println("id\t姓名\t 性别");
			while(jrs.next())
			{
				System.out.println(jrs.getString(1)+"\t"+jrs.getString(2)+"\t"+jrs.getString(3));
			}
		}catch(Exception e)
		{
			e.printStackTrace();
		}
	}
 
}

去掉选择数据库的执行语句 你会发现报一个No database selected的异常。

端口号是否添加,目前都能连接上,原因暂时未知。

根据需求,在选择数据库语句前,需要执行查询数据库操作

jrs.setCommand("show DATABASES");
jrs.execute();
while (jrs.next()) {
    System.out.println(jrs.getString(1));
}

原文链接:JDBC不指定具体数据库的数据库连接_snkcxy的博客-CSDN博客

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要使用Java连接MySQL数据库,首先需要确保已经安装了MySQL数据库,并且能够访问到数据库的地址、端口号、用户和密码。 在Java代码中,可以使用JDBCJava Database Connectivity)来连接MySQL数据库。以下是连接MySQL数据库Java代码示例: 1. 导入需要的类: import java.sql.*; 2. 建立数据库连接: String url = "jdbc:mysql://localhost:3306/mydatabase"; // 数据库地址和端口号 String username = "root"; // 数据库用户 String password = "password"; // 数据库密码 try { Connection connection = DriverManager.getConnection(url, username, password); // 连接成功后可以进行后续操作 } catch (SQLException e) { e.printStackTrace(); } 以上代码中,url变量指定数据库的地址和端口号,username和password变量指定数据库的用户和密码。getConnection方法用于建立数据库连接,如果连接成功则返回一个Connection对象。 建立数据库连接后,就可以通过Connection对象来执行SQL语句和操作数据库了。例如,可以使用Statement对象执行SQL查询语句,使用PreparedStatement对象执行预编译的SQL语句。 需要注意的是,连接MySQL数据库时,还需要引入相应的数据库驱动程序。可以在代码中使用Class.forName方法来加载MySQL的驱动类,例如: Class.forName("com.mysql.jdbc.Driver"); 另外,连接MySQL数据库时需要确保已经在项目的Classpath中添加了MySQL的驱动程序。可以将MySQL的驱动JAR文件添加到项目的Build Path中,或者在项目的构建脚本中添加相应的依赖项。 希望这能帮到你,如果还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值