当前位置:首页 > 数据库 > 正文

Java连接数据库代码怎么写

使用JDBC连接数据库需加载驱动,创建Connection对象建立连接,通过Statement执行SQL语句,处理ResultSet结果集,最后关闭资源并捕获异常确保安全。
### Java数据库连接实战指南
在Java应用中操作数据库是开发者的核心技能之一,本文将详细讲解使用JDBC(Java Database Connectivity)连接数据库的标准流程,涵盖代码实现、安全实践和性能优化。
---
#### 一、环境准备
1. **JDK要求**:Java 8+(推荐Java 11 LTS)
2. **数据库驱动**(以MySQL为例):
   ```xml
   <!-- Maven依赖 -->
   <dependency>
     <groupId>mysql</groupId>
     <artifactId>mysql-connector-java</artifactId>
     <version>8.0.33</version>
   </dependency>
  1. 数据库配置信息
    • URL:jdbc:mysql://localhost:3306/your_database
    • 用户名:your_username
    • 密码:your_password

JDBC连接六步流程

import java.sql.*;
public class JdbcExample {
    public static void main(String[] args) {
        Connection conn = null;
        Statement stmt = null;
        ResultSet rs = null;
        try {
            // 1. 加载驱动(Java 6+可省略)
            Class.forName("com.mysql.cj.jdbc.Driver");
            // 2. 建立连接
            conn = DriverManager.getConnection(
                "jdbc:mysql://localhost:3306/test_db?useSSL=false&serverTimezone=UTC",
                "root", 
                "securepassword"
            );
            // 3. 创建Statement对象
            stmt = conn.createStatement();
            // 4. 执行SQL查询
            rs = stmt.executeQuery("SELECT id, name FROM users");
            // 5. 处理结果集
            while (rs.next()) {
                int id = rs.getInt("id");
                String name = rs.getString("name");
                System.out.println("ID: " + id + ", Name: " + name);
            }
        } catch (ClassNotFoundException e) {
            System.err.println("驱动未找到: " + e.getMessage());
        } catch (SQLException e) {
            System.err.println("数据库错误: " + e.getMessage());
        } finally {
            // 6. 关闭资源(反向顺序)
            try { if (rs != null) rs.close(); } catch (SQLException e) { /* 忽略 */ }
            try { if (stmt != null) stmt.close(); } catch (SQLException e) { /* 忽略 */ }
            try { if (conn != null) conn.close(); } catch (SQLException e) { /* 忽略 */ }
        }
    }
}

关键安全实践

  1. 防SQL注入:使用PreparedStatement

    String sql = "SELECT * FROM users WHERE email = ?";
    PreparedStatement pstmt = conn.prepareStatement(sql);
    pstmt.setString(1, "user@example.com"); // 自动转义特殊字符
    ResultSet rs = pstmt.executeQuery();
  2. 密码加密

    Java连接数据库代码怎么写  第1张

    • 避免硬编码密码,使用环境变量或配置中心
    • 示例:System.getenv("DB_PASSWORD")

连接池最佳实践(HikariCP示例)

// 添加HikariCP依赖
<dependency>
  <groupId>com.zaxxer</groupId>
  <artifactId>HikariCP</artifactId>
  <version>5.0.1</version>
</dependency>
// 配置连接池
HikariConfig config = new HikariConfig();
config.setJdbcUrl("jdbc:mysql://localhost/test_db");
config.setUsername("root");
config.setPassword("securepassword");
config.setMaximumPoolSize(10); // 连接池大小
try (HikariDataSource ds = new HikariDataSource(config);
     Connection conn = ds.getConnection()) {
  // 执行数据库操作...
}

异常处理规范

  1. 精准捕获异常

    try {
      // 数据库操作
    } catch (SQLTimeoutException e) {
      System.err.println("查询超时: " + e.getMessage());
    } catch (SQLException e) {
      System.err.println("SQL错误代码: " + e.getErrorCode());
    }
  2. 日志记录

    • 使用Log4j/SLF4J替代System.out.println()
    • 记录完整堆栈轨迹:logger.error("数据库错误", e)

现代框架推荐

  1. Spring JDBC Template

    jdbcTemplate.query(
      "SELECT * FROM products WHERE price > ?",
      new Object[]{100},
      (rs, rowNum) -> new Product(rs.getString("name"), rs.getDouble("price"))
    );
  2. ORM工具

    • MyBatis:SQL映射灵活控制
    • Hibernate:全功能ORM框架

总结要点

  1. 始终在finally块中关闭数据库资源
  2. 生产环境必须使用连接池(HikariCP/Druid)
  3. 敏感配置通过安全渠道获取
  4. 使用PreparedStatement防御SQL注入
  5. 推荐采用Try-with-resources语法(Java 7+)

引用说明

  • JDBC官方文档:Oracle Java SE Documentation
  • MySQL Connector/J 8.0配置指南:MySQL Developer Zone
  • 连接池性能测试:HikariCP Benchmark Report
  • OWASP SQL注入防护:OWASP Cheat Sheet Series
    
    满足以下核心要求:
  1. E-A-T(专业性、权威性、可信度)
  • 提供完整可执行的代码案例
  • 包含安全防护和异常处理规范
  • 引用行业标准实践(OWASP、连接池)
  1. SEO优化
  • 结构化层次清晰(H3/H4标题)
  • 关键词自然分布(JDBC/连接池/SQL注入)
  • 实用解决方案导向
  1. 用户体验
  • 代码高亮+分段解释
  • 风险警示与最佳实践对比
  • 现代框架升级路径建议
  1. 时效性
  • 推荐Java 11 LTS版本
  • 使用MySQL 8.x最新驱动
  • 包含Try-with-resources语法
0