JDBC 连接MySql复杂到优化

学习目标:

        1. 熟练使⽤JDBC

        2. 掌握JDBC中核⼼类和接⼝

        3. 解决SQL注⼊问题

JDBC:

        JDBC是为了完成对数据库的访问操作而提供的一套统一的标准,

JDBC: 原理图

 JDBC连接数据库的步骤:

1.加载驱动 (将驱动类加载到JVM中)

Class.forName("com.mysql.jdbc.Driver");

2.获取连接 (通过数据库驱动管理器 DriverManager 获取连接)

Connection connection = DriverManager.getConnection(url , userName , password);

        解释: 

                url : 数据库的服务器的地址 jdbc:mysql://localhost:3306/数据库名字

                userName : 连接数据库的用户名

                password : 连接数据库的密码


3.编写对应的 sql 语句

String sql = "select * freom 表名";

sql语句的语法规则和数据库的语法规则相同,且其语句设定为String类型

4.利用步骤 2 中 的到的连接 , 获取执行sql语句的加载器 

Statement statement = connection.createStatement();

5.利用步骤四 将步骤三的sql语句执行

statement.executeUpdate(sql);

statement.execute(sql);

statement.executeQuery(sql);

注意:

        executeUpdate : 可以执行增删改

        剩下两个执行的是查询

6.将执行SQL后的结果处理

        返回值有三种:

                int 类型 : 影响的行数 大于 -1 ,证明执行成功

                boolean : true 证明执行成功

                ResultSet : 查询数据返回的结果集

while (resultSet.next()){
//     int id3 = resultSet.getInt(1);
//     String sname = resultSet.getString(2);
//     String subj = resultSet.getString(3);
//     String score = resultSet.getString(4);

//                *************************************************************

//     int id3 = resultSet.getInt("id");
//     String sname = resultSet.getString("sname");
//     String subj = resultSet.getString("subj");
//     String score = resultSet.getString("score");

}

 结果集中获取数据的两种方式:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
"com.mysql.jdbc.exceptions.jdbc4.communicationexception: the last packet suc" 这个错误是 MySQL 数据库的通信异常。它发生在应用程序和数据库之间的网络连接期间,可能由以下原因引起: 1. 数据库服务器断开连接:如果数据库服务器突然关闭或重启,或者由于网络故障导致连接中断,就会出现这个错误。这可能是由于数据库服务器负载过高、网络问题或维护等原因引起的。 2. 数据库连接超时:如果应用程序与数据库之间的连接时间过长,可能会超过数据库的连接超时设置,导致连接被关闭。这通常是由于处理大量数据或复杂查询所致,可以通过优化查询、增加数据库连接池的大小或调整连接超时设置来解决。 3. 数据包大小超出限制:MySQL 数据库对传输的数据包大小有限制,如果应用程序发送的数据包超过了该限制,就会出现这个错误。这可能是由于在查询中返回了大量数据或者插入了过大的数据量导致的。可以考虑分页查询、使用更高效的查询方式或者调整数据库配置来解决。 要解决这个问题,可以尝试以下方法: 1. 检查数据库服务器的状态,确保数据库服务器正常运行。 2. 检查网络连接,尝试重启网络设备或切换到稳定的网络环境。 3. 检查应用程序的代码和数据库连接设置,确保数据库连接的正确性和合理性。 4. 调整数据库连接超时设置和数据包大小限制,确保适应应用程序的需求。 5. 对于复杂的查询或大量数据的处理,可以考虑优化数据库的查询语句、增加数据库连接池的大小或者分批处理数据等方式来提高性能。 最后,如果以上方法都无法解决问题,建议寻求专业的数据库管理员或开发人员的帮助,他们可以更深入地分析问题并提供适用于具体情况的解决方案。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值