java连数据库

一、准备工作

  1. ​安装MySQL数据库​

    确保已安装MySQL服务器并启动服务

  2. ​下载JDBC驱动​

    • 官方驱动:MySQL Connector/J

    • Maven依赖:

      XML 复制代码
      <dependency>
          <groupId>mysql</groupId>
          <artifactId>mysql-connector-java</artifactId>
          <version>8.0.28</version>
      </dependency>

      <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.28</version> </dependency>

二、基础连接步骤

java 复制代码
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;

public class MySQLDemo {
    // 数据库信息
    static final String URL = "jdbc:mysql://localhost:3306/mydatabase";
    static final String USER = "root";
    static final String PASSWORD = "123456";

    public static void main(String[] args) {
        Connection conn = null;
        try {
            // 1. 加载驱动(JDBC 4.0+ 可自动加载)
            Class.forName("com.mysql.cj.jdbc.Driver");
            
            // 2. 建立连接
            conn = DriverManager.getConnection(URL, USER, PASSWORD);
            
            // 3. 使用连接进行数据库操作
            System.out.println("连接成功!");
            
        } catch (ClassNotFoundException | SQLException e) {
            e.printStackTrace();
        } finally {
            // 4. 关闭连接
            try {
                if(conn != null) conn.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }
}

三、关键参数说明

  1. ​连接URL格式​

    复制代码
    jdbc:mysql://[host][:port]/[database][?参数]
    • 常用参数:
      • useSSL=false 禁用SSL(开发环境建议)
      • serverTimezone=UTC 设置时区
      • characterEncoding=utf8 字符编码
  2. ​推荐完整URL​

    java 复制代码
    String URL = "jdbc:mysql://localhost:3306/mydatabase?useSSL=false&serverTimezone=Asia/Shanghai&characterEncoding=utf8";

四、执行SQL操作

1. 查询数据示例
java 复制代码
Statement stmt = null;
ResultSet rs = null;
try {
    stmt = conn.createStatement();
    rs = stmt.executeQuery("SELECT id, name FROM users");
    
    while(rs.next()) {
        int id = rs.getInt("id");
        String name = rs.getString("name");
        System.out.println(id + ": " + name);
    }
} finally {
    if(rs != null) rs.close();
    if(stmt != null) stmt.close();
}
2. 使用PreparedStatement(推荐)
java 复制代码
String sql = "INSERT INTO users(name, age) VALUES(?, ?)";
try (PreparedStatement pstmt = conn.prepareStatement(sql)) {
    pstmt.setString(1, "张三");
    pstmt.setInt(2, 25);
    int rows = pstmt.executeUpdate();
    System.out.println("插入" + rows + "条记录");
}

五、事务管理

java 复制代码
try {
    conn.setAutoCommit(false); // 关闭自动提交
    
    // 执行多个SQL操作...
    
    conn.commit(); // 提交事务
} catch (SQLException e) {
    try {
        conn.rollback(); // 回滚事务
    } catch (SQLException ex) {
        ex.printStackTrace();
    }
    e.printStackTrace();
} finally {
    conn.setAutoCommit(true); // 恢复自动提交
}

六、常见问题排查

  1. ​驱动加载失败​

    • 确认jar包已正确添加到classpath
    • 检查驱动类名是否正确(新版使用com.mysql.cj.jdbc.Driver
  2. ​连接超时​

    • 检查MySQL服务是否运行
    • 验证用户名/密码是否正确
    • 检查防火墙设置
  3. ​时区问题​

    java 复制代码
    // 在连接URL中添加时区参数 ?serverTimezone=Asia/Shanghai

七、连接池推荐

对于生产环境,建议使用连接池:

  • HikariCP(性能最佳)
  • Druid(阿里出品,带监控功能)

HikariCP简单示例:

java 复制代码
HikariConfig config = new HikariConfig();
config.setJdbcUrl(URL);
config.setUsername(USER);
config.setPassword(PASSWORD);

try (HikariDataSource ds = new HikariDataSource(config);
     Connection conn = ds.getConnection()) {
    // 使用连接...
}
相关推荐
Black_Cat_yyds17 分钟前
rabbitmq
java·rabbitmq·java-rabbitmq
摆烂且佛系32 分钟前
FastByteArrayOutputStream和ByteArrayInputStream有什么区别
java·开发语言
hie988941 小时前
使用Spring Boot集成Nacos
java·spring boot·后端
珹洺1 小时前
Jsp技术入门指南【十四】实现基于MySQL+JDBC+JSP数据库验证的登录界面与登录跳转功能
java·运维·数据库·mysql·servlet
像风一样自由20201 小时前
MQTT协议技术详解:深入理解物联网通信基础
java·物联网·struts
JhonKI1 小时前
【MySQL】日志缓冲区详解 以及 InnoDB内存结构总结
数据库·mysql·oracle
oneDay++1 小时前
# IntelliJ IDEA企业版开发入门:包、类与项目结构详解
java·经验分享·学习·intellij-idea·学习方法
程序员阿鹏1 小时前
Git的安装和配置(idea中配置Git)
java·开发语言·ide·git·intellij-idea·idea
vvilkim2 小时前
MySQL视图:虚拟表的强大功能与应用实践
数据库·mysql
Musennn2 小时前
102. 二叉树的层序遍历详解:队列操作与层级分组的核心逻辑
java·数据结构·算法·leetcode