1 引言
最近读一些Java Web开发类的书籍时,发现书中的连接数据库的过程缺少了一些关键性的过程,这对初学者非常不友好。为此,本文将给出详细的连接MySQL数据库的过程,并且是纯手工,不依赖于pom.xml和Web容器,也不用任何IDE工具,编译和运行全部手写命令,以期对初学者从底层更好地理解整个数据库连接过程有所帮助。
所基于的环境如下:
名称 | 版本 |
---|---|
JDK | 1.8.0_281 |
MySQL | 8.0.13 |
2 连接MySQL数据库详细过程
-
建立文件夹结构。建立一个文件夹testDAO,在其中建立如下子文件夹:
-
查询本机安装的MySQL版本,如下:
-
从maven仓库下载针对MySQL连接Java的驱动
mysql-connector-java-8.0.13.jar
,如下图:
将下载好的
mysql-connector-java-8.0.13.jar
保存到文件夹lib中。 -
编写代码DBConnection.java,放入到src中的com/rob/db文件夹中。代码如下:
java
package com.rob.db;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
public class DBConnection {
private static final String Driver = "com.mysql.cj.jdbc.Driver";
private static final String URL = "jdbc:mysql://localhost:3306/testseb";
private static final String USER = "root";
private static final String PASSWORD = "123456";
private Connection conn = null;
public DBConnection() throws Exception {
try {
Class.forName(Driver);
this.conn = DriverManager.getConnection(URL, USER, PASSWORD);
} catch(Exception e) {
throw e;
}
}
public Connection getConnection(){
return this.conn;
}
public void close() throws Exception {
if (this.conn != null){
try {
this.conn.close();
} catch (Exception e) {
throw e;
}
}
}
// unit test
public static void main(String[] args) throws Exception {
DBConnection dbconn = new DBConnection();
System.out.println("连接成功");
try {
dbconn.close();
} catch (SQLException e) {
e.printStackTrace();
}
}
}
- 编译,用如下命令:
javac -classpath lib\mysql-connector-java-8.0.13.jar -d classes src\com\rob\db\DBConnection.java
。如下图:
- 运行。注意运行时也必须指定jar包所在的路径。命令为:
java -classpath classes;lib/mysql-connector-java-8.0.13.jar;. com/rob/db/DBConnection
。如下图:
从上面可以看出,已经连接成功。之所以抛出异常,是因为MySQL中还没创建数据库testseb,这反而说明了连接数据库已经成功。
3 总结
本文讲解了Java中手工连接MySQL数据库的详细过程,从建立文件夹结构、下载jar驱动、编写代码到编译、运行,对于初学者从底层了解整个过程非常有帮助,而不被各式的IDE工具所屏蔽底层的编译运行细节。这会让我们后续在使用各种IDE工具时更加从容。