Java JDBC入门教程:连接MySQL数据库

需积分: 5 0 下载量 13 浏览量 更新于2024-08-05 收藏 41KB TXT 举报
"这篇文档是关于JDBC的简单入门教程,涵盖了JDBC的基本概念、环境配置以及初步的代码实现步骤。" JDBC(Java Database Connectivity)是Java平台中用于与关系型数据库交互的一组标准接口和类,由Sun Microsystems开发并注册为商标。通过JDBC,Java开发者可以方便地进行数据库的查询、更新等操作,而无需深入学习不同数据库供应商的特定驱动API。在没有JDBC的情况下,与MySQL或Oracle等数据库的连接需要直接使用对应的数据库驱动API。 JDBC环境准备通常包括以下几个步骤: 1. 创建数据库和表:例如,在MySQL中创建一个名为`web_test3`的数据库,然后在该数据库下创建一个名为`user`的表,包含`id`(主键,自动增长)、`username`、`password`、`nickname`和`age`字段,并插入一些初始数据。 2. 搭建Java项目:在集成开发环境(如IntelliJ IDEA)中创建一个新的Java项目。为了使用JDBC,需要引入数据库驱动的JAR包。以MySQL为例,需要下载`mysql-connector-java-5.0.8-bin.jar`并将其放入项目中的`lib`文件夹。 3. 配置项目依赖:在IDE的项目结构设置中,将`lib`文件夹添加为库的管理目录,这样项目就能识别并使用JDBC驱动。 4. 编写代码:在Java项目中创建一个包和Java类,如`JDBCDemo1`,并在其中编写测试方法。JDBC的基本操作通常包括以下步骤: - 加载驱动:通过`Class.forName()`方法加载数据库驱动,例如对于MySQL,使用`"com.mysql.jdbc.Driver"`。 - 获取连接:使用`DriverManager.getConnection()`方法建立到数据库的连接,需要提供URL、用户名和密码。 - 创建Statement或PreparedStatement对象:用于执行SQL语句,例如`Statement stmt = conn.createStatement();`或`PreparedStatement pstmt = conn.prepareStatement(sql);` - 执行SQL:调用Statement或PreparedStatement对象的方法执行查询或更新操作,如`stmt.executeQuery(sql)`或`pstmt.executeUpdate()` - 处理结果集:对于查询操作,需要遍历`ResultSet`对象来获取结果。 - 关闭资源:操作完成后,记得关闭Statement、ResultSet和Connection,避免资源泄漏。 入门代码示例: ```java import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; public class JDBCDemo1 { @Test public void demo1() throws Exception { // 1. 加载驱动 Class.forName("com.mysql.jdbc.Driver"); // 2. 获取连接 String url = "jdbc:mysql://localhost:3306/web_test3"; String user = "your_username"; String password = "your_password"; Connection conn = DriverManager.getConnection(url, user, password); // 3. 创建Statement对象并执行SQL Statement stmt = conn.createStatement(); String sql = "SELECT * FROM user"; ResultSet rs = stmt.executeQuery(sql); // 4. 处理结果集 while (rs.next()) { int id = rs.getInt("id"); String username = rs.getString("username"); String nickname = rs.getString("nickname"); int age = rs.getInt("age"); System.out.println("ID: " + id + ", Username: " + username + ", Nickname: " + nickname + ", Age: " + age); } // 5. 关闭资源 rs.close(); stmt.close(); conn.close(); } } ``` 在实际应用中,为了提高代码的可读性和安全性,通常会使用`PreparedStatement`来防止SQL注入,并通过连接池(如C3P0、HikariCP或Apache DBCP)管理数据库连接,以提高性能和资源利用率。此外,JDBC事务管理、批处理操作、异常处理等也是JDBC开发中常见的主题。