【Java-Mysql】数据库连接的五种方式

前言
数据库连接一般有一下五种方式,最常用的方式为方式四、方式五,其他的也可以了解掌握。


举例:
数据库:db01
用户:root
密码:123456

  • 方式一
//获取 Driver 实现类对象
Driver driver = new com.mysql.jdbc.Driver();
String url = "jdbc:mysql://localhost:3306/db01";
Properties info = new Properties();
info.setProperty("user" , "root");
info.setProperty("password", "123456");
Connection conn = driver.connect(url, info);
if (conn != null){
	System.out.println("连接成功。");
}

缺点:直接使用com.mysql.jdbc.Driver(),属于静态加载,灵活性差


  • 方式二
//利用反射
Class cls = Class.forName("com.mysql.jdbc.Driver");
Driver driver =(Driver) cls.newInstance();
String url = "jdbc:mysql://localhost:3306/db01";
Properties info = new Properties();
info.setProperty("user", "root");
info.setProperty("password","123456");
Connection conn = driver.connect(url, info);
if (conn != null) {
    System.out.println("连接成功。");
}

利用了反射机制,属于动态加载方式,相对方式一提高了灵活性。


  • 方式三
//使用 DriverManager替换 Driver
Class cls = Class.forName("com.mysql.jdbc.Driver");
Driver driver = (Driver) cls.newInstance();
String url = "jdbc:mysql://localhost:3306/db01";
String user = "root";
String password = "123456";
DriverManager.registerDriver(driver);
Connection conn = DriverManager.getConnection(url, user, password);
if (conn != null) {
    System.out.println("连接成功。");
}

  • 方式四
//使用 Class.forName() 自动完成注册驱动,简化代码
	//原因:Driver类有静态代码块在类加载时自动执行了
	//语句 DriverManager.registerDriver(new Driver());
Class.forName("com.mysql.jdbc.Driver");
String url = "jdbc:mysql://localhost:3306/db01";
String user = "root";
String password = "123456";
Connection conn = DriverManager.getConnection(url, user, password);
if (conn != null) {
    System.out.println("连接成功。");
}

提示:
1. mysqL驱动5.1.6可以无需CLass . forName(“com.mysql.jdbc.Driver”)。
2. 从jdk1.5 以后使用了jdbc4,不再需要显示调用class.forName()注册驱动而是自动调用驱动jar包下META-INF\services\java.sql.Driver文本中的类名称去注册。
3. 建议还是写上CLass . forName(“com.mysql.jdbc.Driver”),更加明确。


  • 方式五
//通过 Properties 对象获取配置文件的信息
Properties properties = new Properties();
properties.load(new FileInputStream("src\\mysql.properties"));
//获取相关的值
String driver = properties.getProperty("driver");
String url = properties.getProperty("url");
String user = properties.getProperty("user");
String password = properties.getProperty("password");

Class.forName(driver);//建议写上
Connection conn = DriverManager.getConnection(url, user, password);
if (conn != null) {
    System.out.println("连接成功。");
}

mysql.properties文件:
 
在这里插入图片描述

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
使用MySQL Connector/J连接MySQL数据库的步骤如下: 1. 下载MySQL Connector/J jar包,可以从MySQL官网下载。 2. 将下载的jar包添加到classpath中。 3. 加载驱动程序。 ```java Class.forName("com.mysql.cj.jdbc.Driver"); ``` 4. 创建数据库连接。 ```java String url = "jdbc:mysql://localhost:3306/test"; String user = "root"; String password = "123456"; Connection conn = DriverManager.getConnection(url, user, password); ``` 其中,url是数据库连接地址,user是连接数据库的用户名,password是连接数据库的密码。 5. 执行SQL语句。 ```java Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT * FROM users"); while (rs.next()) { int id = rs.getInt("id"); String name = rs.getString("name"); int age = rs.getInt("age"); System.out.println("id=" + id + ", name=" + name + ", age=" + age); } ``` 6. 关闭数据库连接。 ```java rs.close(); stmt.close(); conn.close(); ``` 完整的示例代码如下: ```java import java.sql.*; public class DBTest { public static void main(String[] args) throws SQLException, ClassNotFoundException { // 加载驱动程序 Class.forName("com.mysql.cj.jdbc.Driver"); // 创建数据库连接 String url = "jdbc:mysql://localhost:3306/test"; String user = "root"; String password = "123456"; Connection conn = DriverManager.getConnection(url, user, password); // 执行SQL语句 Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery("SELECT * FROM users"); while (rs.next()) { int id = rs.getInt("id"); String name = rs.getString("name"); int age = rs.getInt("age"); System.out.println("id=" + id + ", name=" + name + ", age=" + age); } // 关闭数据库连接 rs.close(); stmt.close(); conn.close(); } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值