JDBC知识【JDBC API详解】第三章上篇

举报
爱吃豆的土豆 发表于 2022/09/25 02:16:08 2022/09/25
【摘要】 目录 💂 个人主页: 爱吃豆的土豆 🌈欢迎加入社区,福利多多哦!土豆社区 🤟 版权: 本文由【爱吃豆的土豆】原创、在CSDN首发、需要转载请联系博主💬 如果文章对你有帮助、欢迎关注、点赞、收藏(一键三连)和订阅专栏哦 🏆人必有所执,方能有所成! 1,JDBC API详解 1.1:Driver...

目录

  • 💂 个人主页: 爱吃豆的土豆
  • 🌈欢迎加入社区,福利多多哦!土豆社区

  • 🤟 版权: 本文由【爱吃豆的土豆】原创、在CSDN首发、需要转载请联系博主
  • 💬 如果文章对你有帮助、欢迎关注、点赞、收藏(一键三连)和订阅专栏哦
  • 🏆人必有所执,方能有所成!

1,JDBC API详解

1.1:DriverManager

1.2:Connection

1.2.1:获取执行对象

1.2.2:事务管理

1.3:Statement

1.3.1:概述

1.3.2:代码实现

1.4:ResultSet

1.4.1:概述

1.4.2:代码实现


1,JDBC API详解

1.1:DriverManager

DriverManager(驱动管理类)作用:

  • 注册驱动

  •  

    registerDriver方法是用于注册驱动的,但是我们之前做的入门案例并不是这样写的。而是如下实现

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

    我们查询MySQL提供的Driver类,看它是如何实现的,源码如下:

  •  

    在该类中的静态代码块中已经执行了 DriverManager 对象的 registerDriver() 方法进行驱动的注册了,那么我们只需要加载 Driver 类,该静态代码块就会执行。而 Class.forName("com.mysql.jdbc.Driver"); 就可以加载 Driver 类。

    ==提示:==

    • MySQL 5之后的驱动包,可以省略注册驱动的步骤

    • 自动加载jar包中META-INF/services/java.sql.Driver文件中的驱动类

  • 获取数据库连接

  •  

    参数说明:

    • url : 连接路径

      语法:jdbc:mysql://ip地址(域名):端口号/数据库名称?参数键值对1&参数键值对2…

      示例:jdbc:mysql://127.0.0.1:3306/db1

      ==细节:==

      • 如果连接的是本机mysql服务器,并且mysql服务默认端口是3306,则url可以简写为:jdbc:mysql:///数据库名称?参数键值对

      • 配置 useSSL=false 参数,禁用安全连接方式,解决警告提示

    • user :用户名

    • poassword :密码

1.2:Connection

Connection(数据库连接对象)作用:

  • 获取执行 SQL 的对象

  • 管理事务

1.2.1:获取执行对象

  • 普通执行SQL对象

    Statement createStatement()

    入门案例中就是通过该方法获取的执行对象。

  • 预编译SQL的执行SQL对象:防止SQL注入

    PreparedStatement  prepareStatement(sql)

    通过这种方式获取的 PreparedStatement SQL语句执行对象是我们一会重点要进行讲解的,它可以防止SQL注入。

  • 执行存储过程的对象

    CallableStatement prepareCall(sql)

    通过这种方式获取的 CallableStatement 执行对象是用来执行存储过程的,而存储过程在MySQL中不常用,所以这个我们将不进行讲解。

1.2.2:事务管理

先回顾一下MySQL事务管理的操作:

  • 开启事务 : BEGIN; 或者 START TRANSACTION;

  • 提交事务 : COMMIT;

  • 回滚事务 : ROLLBACK;

MySQL默认是自动提交事务

接下来学习JDBC事务管理的方法。

Connection几口中定义了3个对应的方法:

 

具体代码实现如下:  


  
  1. /**
  2. * JDBC API 详解:Connection
  3. */
  4. public class JDBCDemo3_Connection {
  5. public static void main(String[] args) throws Exception {
  6. //1. 注册驱动
  7. //Class.forName("com.mysql.jdbc.Driver");
  8. //2. 获取连接:如果连接的是本机mysql并且端口是默认的 3306 可以简化书写
  9. String url = "jdbc:mysql:///db1?useSSL=false";
  10. String username = "root";
  11. String password = "1234";
  12. Connection conn = DriverManager.getConnection(url, username, password);
  13. //3. 定义sql
  14. String sql1 = "update account set money = 3000 where id = 1";
  15. String sql2 = "update account set money = 3000 where id = 2";
  16. //4. 获取执行sql的对象 Statement
  17. Statement stmt = conn.createStatement();
  18. try {
  19. // ============开启事务==========
  20. conn.setAutoCommit(false);
  21. //5. 执行sql
  22. int count1 = stmt.executeUpdate(sql1);//受影响的行数
  23. //6. 处理结果
  24. System.out.println(count1);
  25. int i = 3/0;
  26. //5. 执行sql
  27. int count2 = stmt.executeUpdate(sql2);//受影响的行数
  28. //6. 处理结果
  29. System.out.println(count2);
  30. // ============提交事务==========
  31. //程序运行到此处,说明没有出现任何问题,则需求提交事务
  32. conn.commit();
  33. } catch (Exception e) {
  34. // ============回滚事务==========
  35. //程序在出现异常时会执行到这个地方,此时就需要回滚事务
  36. conn.rollback();
  37. e.printStackTrace();
  38. }
  39. //7. 释放资源
  40. stmt.close();
  41. conn.close();
  42. }
  43. }

1.3:Statement

1.3.1:概述

Statement对象的作用就是用来执行SQL语句。而针对不同类型的SQL语句使用的方法也不一样。

 

1.3.2:代码实现

执行DML语句


  
  1. /**
  2. * 执行DML语句
  3. * @throws Exception
  4. */
  5. @Test
  6. public void testDML() throws Exception {
  7. //1. 注册驱动
  8. //Class.forName("com.mysql.jdbc.Driver");
  9. //2. 获取连接:如果连接的是本机mysql并且端口是默认的 3306 可以简化书写
  10. String url = "jdbc:mysql:///db1?useSSL=false";
  11. String username = "root";
  12. String password = "1234";
  13. Connection conn = DriverManager.getConnection(url, username, password);
  14. //3. 定义sql
  15. String sql = "update account set money = 3000 where id = 1";
  16. //4. 获取执行sql的对象 Statement
  17. Statement stmt = conn.createStatement();
  18. //5. 执行sql
  19. int count = stmt.executeUpdate(sql);//执行完DML语句,受影响的行数
  20. //6. 处理结果
  21. //System.out.println(count);
  22. if(count > 0){
  23. System.out.println("修改成功~");
  24. }else{
  25. System.out.println("修改失败~");
  26. }
  27. //7. 释放资源
  28. stmt.close();
  29. conn.close();
  30. }

执行DDL语句


  
  1. /**
  2. * 执行DDL语句
  3. * @throws Exception
  4. */
  5. @Test
  6. public void testDDL() throws Exception {
  7. //1. 注册驱动
  8. //Class.forName("com.mysql.jdbc.Driver");
  9. //2. 获取连接:如果连接的是本机mysql并且端口是默认的 3306 可以简化书写
  10. String url = "jdbc:mysql:///db1?useSSL=false";
  11. String username = "root";
  12. String password = "1234";
  13. Connection conn = DriverManager.getConnection(url, username, password);
  14. //3. 定义sql
  15. String sql = "drop database db2";
  16. //4. 获取执行sql的对象 Statement
  17. Statement stmt = conn.createStatement();
  18. //5. 执行sql
  19. int count = stmt.executeUpdate(sql);//执行完DDL语句,可能是0
  20. //6. 处理结果
  21. System.out.println(count);
  22. //7. 释放资源
  23. stmt.close();
  24. conn.close();
  25. }

 

  • 注意:

    • 以后开发很少使用java代码操作DDL语句

1.4:ResultSet

1.4.1:概述

ResultSet(结果集对象)作用:

  • ==封装了SQL查询语句的结果。==

而执行了DQL语句后就会返回该对象,对应执行DQL语句的方法如下:

ResultSet  executeQuery(sql):执行DQL 语句,返回 ResultSet 对象

那么我们就需要从 ResultSet 对象中获取我们想要的数据。ResultSet 对象提供了操作查询结果数据的方法,如下:

boolean next()

  • 将光标从当前位置向前移动一行

  • 判断当前行是否为有效行

方法返回值说明:

  • true : 有效航,当前行有数据

  • false : 无效行,当前行没有数据

xxx getXxx(参数):获取数据

  • xxx : 数据类型;如: int getInt(参数) ;String getString(参数)

  • 参数

    • int类型的参数:列的编号,从1开始

    • String类型的参数: 列的名称

如下图为执行SQL语句后的结果

 一开始光标指定于第一行前,如图所示红色箭头指向于表头行。当我们调用了 next() 方法后,光标就下移到第一行数据,并且方法返回true,此时就可以通过 getInt("id") 获取当前行id字段的值,也可以通过 getString("name") 获取当前行name字段的值。如果想获取下一行的数据,继续调用 next() 方法,以此类推。

1.4.2:代码实现


  
  1. /**
  2. * 执行DQL
  3. * @throws Exception
  4. */
  5. @Test
  6. public void testResultSet() throws Exception {
  7. //1. 注册驱动
  8. //Class.forName("com.mysql.jdbc.Driver");
  9. //2. 获取连接:如果连接的是本机mysql并且端口是默认的 3306 可以简化书写
  10. String url = "jdbc:mysql:///db1?useSSL=false";
  11. String username = "root";
  12. String password = "1234";
  13. Connection conn = DriverManager.getConnection(url, username, password);
  14. //3. 定义sql
  15. String sql = "select * from account";
  16. //4. 获取statement对象
  17. Statement stmt = conn.createStatement();
  18. //5. 执行sql
  19. ResultSet rs = stmt.executeQuery(sql);
  20. //6. 处理结果, 遍历rs中的所有数据
  21. /* // 6.1 光标向下移动一行,并且判断当前行是否有数据
  22. while (rs.next()){
  23. //6.2 获取数据 getXxx()
  24. int id = rs.getInt(1);
  25. String name = rs.getString(2);
  26. double money = rs.getDouble(3);
  27. System.out.println(id);
  28. System.out.println(name);
  29. System.out.println(money);
  30. System.out.println("--------------");
  31. }*/
  32. // 6.1 光标向下移动一行,并且判断当前行是否有数据
  33. while (rs.next()){
  34. //6.2 获取数据 getXxx()
  35. int id = rs.getInt("id");
  36. String name = rs.getString("name");
  37. double money = rs.getDouble("money");
  38. System.out.println(id);
  39. System.out.println(name);
  40. System.out.println(money);
  41. System.out.println("--------------");
  42. }
  43. //7. 释放资源
  44. rs.close();
  45. stmt.close();
  46. conn.close();
  47. }

文章来源: qianxu.blog.csdn.net,作者:爱吃豆的土豆,版权归原作者所有,如需转载,请联系作者。

原文链接:qianxu.blog.csdn.net/article/details/126481796

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。