• JDBC工具类


    1. import java.sql.Connection;
    2. import java.sql.DriverManager;
    3. import java.sql.ResultSet;
    4. import java.sql.Statement;
    5. public class JDBC {
    6. public static void main(String[] args) throws Exception{
    7. //1.导入jar包
    8. //2.注册驱动
    9. Class.forName("com.mysql.jdbc.Driver");
    10. //3.获取连接
    11. Connection con = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/test","root","root");
    12. //4.获取执行者对象
    13. Statement stat = con.createStatement();
    14. //5.执行sql语句,并且接收结果
    15. String sql = "SELECT * FROM user";
    16. ResultSet rs = stat.executeQuery(sql);
    17. //6.处理结果
    18. while(rs.next()) {
    19. System.out.println(rs.getInt("id") + "\t" + rs.getString("name"));
    20. }
    21. //7.释放资源
    22. con.close();
    23. stat.close();
    24. con.close();
    25. }
    26. }

    JDBC各个功能类详解

    1.DriverManager

    • DriverManager:驱动管理对象

      • 注册驱动(告诉程序该使用哪一个数据库驱动)

        • static void registerDriver(Driver driver):注册与给定的驱动程序 DriverManager

        • 写代码使用:Class.forName("com.mysql.jdbc.Driver");

        • 通过查看源码发现:在com.mysql.jdbc.Driver类中存在静态代码块

        static {
            try {
                java.sql.DriverManager.registerDriver(new Driver());
            } catch (SQLException E) {
                throw new RuntimeException("Can't register driver!");
            }
        }
        • 注意:mysql5之后的驱动jar包可以省略注册驱动的步骤。在jar包中,存在一个java.sql.Driver配置文件,文件中指定了com.mysql.jdbc.Driver

      • 获取数据库连接(获取到数据库的连接并返回连接对象)

        • static Connection getConnection(String url, String user, String password);

          • 返回值:Connection数据库连接对象

          • 参数

            • url:指定连接的路径。语法:jdbc:mysql://ip地址(域名):端口号/数据库名称

            • user:用户名

            • password:密码

    2.Connection

    • Connection:数据库连接对象

      • 获取执行者对象

        • 获取普通执行者对象:Statement createStatement();

        • 获取预编译执行者对象:PreparedStatement prepareStatement(String sql);

      • 管理事务

        • 开启事务:setAutoCommit(boolean autoCommit); 参数为false,则开启事务。

        • 提交事务:commit();

        • 回滚事务:rollback();

      • 释放资源

        • 立即将数据库连接对象释放:void close();

    3.Statement

    • Statement:执行sql语句的对象

      • 执行DML语句:int executeUpdate(String sql);

        • 返回值int:返回影响的行数。

        • 参数sql:可以执行insert、update、delete语句。

      • 执行DQL语句:ResultSet executeQuery(String sql);

        • 返回值ResultSet:封装查询的结果。

        • 参数sql:可以执行select语句。

      • 释放资源

        • 立即将执行者对象释放:void close();

    4.ResultSet

    • ResultSet:结果集对象

      • 判断结果集中是否还有数据:boolean next();

        • 有数据返回true,并将索引向下移动一行

        • 没有数据返回false

      • 获取结果集中的数据:XXX getXxx("列名");

        • XXX代表数据类型(要获取某列数据,这一列的数据类型)

        • 例如:String getString("name"); int getInt("age");

      • 释放资源

        • 立即将结果集对象释放:void close();

  • 相关阅读:
    VectorDraw Developer Framework 10.1001 Crack
    Spring的7种事务传播机制
    Unity 3D 基础——Coroutine 协同程序
    2022.09.19 学习笔记
    CVPR2022 | 简单高效的语义分割体系结构
    一文带你了解BI的前世今身与企业数字化转型的关系
    lodash已死?Radash库方法介绍及源码解析 —— 异步方法篇
    给LaTeX公式添加优美的注解;日更『数据科学』面试题集锦;大学生『计算机』自学指南;个人防火墙;前沿资料/论文 | ShowMeAI资讯日报
    亚马逊、Lazada、Shopee、速卖通、阿里国际、美客多、eBay、沃尔玛测评自养号,产品权重该如何提高?
    【K8s】部署自定义项目到K8s集群上运行
  • 原文地址:https://blog.csdn.net/weixin_56462645/article/details/128189807