JDBC部分重要的API

JDBC API

导语:

提前创建好名称为abc的表。
在这里插入图片描述

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 :密码

package com.jdbc;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.Statement;

/**
 * JDBC快速入门
 */
public class Demo2_DriverManager {
    public static void main(String[] args) throws Exception {
        //1,注册驱动
        //可以省略注册驱动的步骤
        //Class.forName("com.mysql.jdbc.Driver");

        //2,获取连接
        //String url = "jdbc:mysql://127.0.0.1:3306/a";
        //mysql对应的IP(127.0.0.1):端口(3306)/数据库的名称(a);
        //如果连接的是本机mysql并且端口是默认的3306,如果连接的是本机mysql服务器,并且mysql服务默认端口是3306,
        //则url可以简写为:jdbc:mysql:///数据库名称?参数键值对
        String url = "jdbc:mysql:///a?useSSL=false";//配置 useSSL=false 参数,禁用安全连接方式,解决警告提示
        String username = "root";
        String password= "1234";
        Connection a = DriverManager.getConnection(url,username,password);

        //3,定义sql
        String sql = "update abc set money = 8000 where id = 2";

        //4,获取执行sql的对象Statement
        Statement b = a.createStatement();

        //5,执行sql
        int count = b.executeUpdate(sql);//受影响的行数

        //6,处理结果
        System.out.println(count);

        //7,释放资源
        //先开的Connection,后开的Statement。所以释放的时候要先释放Statement,后释放Connection。
        b.close();
        a.close();

    }
}

2.Connection

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

  • 获取执行 SQL 的对象
  • 管理事务

1 获取执行对象

  • 普通执行SQL对象

    Statement createStatement()
    

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

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

    PreparedStatement  prepareStatement(sql)
    

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

  • 执行存储过程的对象

    CallableStatement prepareCall(sql)
    

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

2 事务管理

MySQL事务管理的操作:

  • 开启事务 : BEGIN; 或者 START TRANSACTION;
  • 提交事务 : COMMIT;
  • 回滚事务 : ROLLBACK;

MySQL默认是自动提交事务

JDBC事务管理的方法。

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

  • 开启事务

在这里插入图片描述

参与autoCommit 表示是否自动提交事务,true表示自动提交事务,false表示手动提交事务。而开启事务需要将该参数设为为false。

  • 提交事务

在这里插入图片描述

  • 回滚事务

在这里插入图片描述

代码实现如下:

package com.jdbc;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;

/**
 * Connection(数据库连接对象)作用:
 * 1,获取执行SQL的对象
 * 2,管理事务
 */
public class Demo3_Connection {
    public static void main(String[] args) throws Exception {
        //1,注册驱动(可省略)

        //2,获取连接
        String url = "jdbc:mysql:///a?useSSL=false";
        String username = "root";
        String password= "1234";
        Connection a = DriverManager.getConnection(url,username,password);

        //3,定义sql
        String sql1 = "update abc set money = 3000 where id = 1";
        String sql2 = "update abc set money = 8000 where id = 2";

        //4,获取执行sql的对象Statement
        Statement b = a.createStatement();

        
        //开启事务
        a.setAutoCommit(false);
        try {
            //5,执行sql
            int count1 = b.executeUpdate(sql1);//受影响的行数
            //6,处理结果
            System.out.println(count1);

            //5,执行sql
            int count2 = b.executeUpdate(sql2);//受影响的行数
            //6,处理结果
            System.out.println(count2);

            //提交事务
            a.commit();
        } catch (Exception e) {
            //回滚事务
            a.rollback();
            throw new RuntimeException(e);
        }


        //7,释放资源
        //先开的Connection,后开的Statement。所以释放的时候要先释放Statement,后释放Connection。
        b.close();
        a.close();

    }
}

3.Statement

1 概述

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

  • 执行DDL、DML语句
    在这里插入图片描述

  • 执行DQL语句

在这里插入图片描述

该方法涉及到了 ResultSet 对象。

2 代码实现

  • 执行DML语句

    /***
         * 执行DML语句(对数据进行增删改)
         * @throws Exception
         */
        @Test
        public void testDML() throws Exception {
                //1,注册驱动(可省略)
                //2,获取连接
                String url = "jdbc:mysql:///a?useSSL=false";
                String username = "root";
                String password= "1234";
                Connection a = DriverManager.getConnection(url,username,password);
                //3,定义sql
                String sql = "update abc set money = 3000 where id = 1";
                //4,获取执行sql的对象Statement
                Statement b = a.createStatement();
                //5,执行sql
                int count = b.executeUpdate(sql);//执行完DML语句后,返回受影响的行数
                //6,处理结果
                if(count>0){
                    System.out.println("修改成功");
                }else{
                    System.out.println("修改失败");
                }
                //7,释放资源
                b.close();
                a.close();
            }
    
  • 执行DDL语句

    /***
         * 执行DDL语句(对数据进行增删改)
         * @throws Exception
         */
        @Test
        public void testDDL() throws Exception {
            //1,注册驱动(可省略)
            //2,获取连接
            String url = "jdbc:mysql:///a?useSSL=false";
            String username = "root";
            String password= "1234";
            Connection a = DriverManager.getConnection(url,username,password);
            //3,定义sql
            String sql = "create database b";
            //4,获取执行sql的对象Statement
            Statement b = a.createStatement();
            //5,执行sql
            int count = b.executeUpdate(sql);//执行完DDL语句后,返回的数可能是0。DDL语句执行完之后不报异常就OK。
            //6,处理结果
            System.out.println(count);
            System.out.println("添加数据库成功");
            //7,释放资源
            b.close();
            a.close();
        }
    

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

4.ResultSet

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() 方法,以此类推。

2 代码实现

package com.jdbc;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;

/**
 *JDBC API 详解:ResultSet
 */
public class Demo5_ResultSet {
    /***
     *
     * 执行DQL(查询语句)
     * @throws Exception
     */
    public static void main(String[] args) throws Exception {
        //1,注册驱动(可省略)

        //2,获取连接
        String url = "jdbc:mysql:///a?useSSL=false";
        String username = "root";
        String password= "1234";
        Connection a = DriverManager.getConnection(url,username,password);

        //3,定义sql
        String sql = "select * from abc";

        //4,获取执行sql的对象Statement
        Statement b = a.createStatement();

        //5,执行sql
        ResultSet c = b.executeQuery(sql);

        //6,处理结果,遍历c中的所有数据
        //6.1 光标向下移动一行,并且判断当前行是否有数据
        while(c.next()){
            //6.2 获取数据 getXxx()
            //int id = c.getInt(1);
            //String name = c.getString(2);
            //double money = c.getDouble(3);

            //6.2 获取数据 getXxx()
            int id = c.getInt("id");
            String name = c.getString("name");
            double money = c.getDouble("money");

            System.out.println(id);
            System.out.println(name);
            System.out.println(money);

            System.out.println("-------------");
        }
        
        //7,释放资源
        c.close();
        b.close();
        a.close();

    }
}

5.案例

  • 需求:查询abc账户表数据,封装为ABC对象中,并且存储到ArrayList集合中

在这里插入图片描述

  • 代码实现

    //定义实体类ABC
    package com.pojo;
    
    public class ABC {
    
        private int id;
        private String name;
        private double money;
    
        public int getId() {
            return id;
        }
    
        public void setId(int id) {
            this.id = id;
        }
    
        public String getName() {
            return name;
        }
    
        public void setName(String name) {
            this.name = name;
        }
    
        public double getMoney() {
            return money;
        }
    
        public void setMoney(double money) {
            this.money = money;
        }
    
        @Override
        public String toString() {
            return "ABC{" +
                    "id=" + id +
                    ", name='" + name + '\'' +
                    ", money=" + money +
                    '}';
        }
    }
    
    
    package com.jdbc;
    
    import com.pojo.ABC;
    
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.ResultSet;
    import java.sql.Statement;
    import java.util.ArrayList;
    import java.util.List;
    
    /**
     *JDBC API 详解:ResultSet
     * 查询abc账户表数据,封装为ABC对象中,并且存储到ArrayList集合中
     *   1. 定义实体类ABC
     *   2. 查询数据,封装到ABC对象中
     *   3. 将ABC对象存入ArrayList集合中
     */
    public class Demo5_ResultSet2 {
        public static void main(String[] args) throws Exception {
            //1,注册驱动(可省略)
    
            //2,获取连接
            String url = "jdbc:mysql:///a?useSSL=false";
            String username = "root";
            String password= "1234";
            Connection a = DriverManager.getConnection(url,username,password);
    
            //3,定义sql
            String sql = "select * from abc";
    
            //4,获取执行sql的对象Statement
            Statement b = a.createStatement();
    
            //5,执行sql
            ResultSet c = b.executeQuery(sql);
    
            //创建集合e
            List<ABC> e = new ArrayList<>();
    
            //6,处理结果,遍历c中的所有数据
            //6.1 光标向下移动一行,并且判断当前行是否有数据
            while(c.next()){
                //创建对象
                ABC d = new ABC();
    
                //获取数值
                int id = c.getInt("id");
                String name = c.getString("name");
                double money = c.getDouble("money");
    
                //给对象赋值
                d.setId(id);
                d.setName(name);
                d.setMoney(money);
    
                //对象数据存入集合
                e.add(d);
            }
    
            System.out.println(e);
    
            //7,释放资源
            c.close();
            b.close();
            a.close();
    
        }
    }
    
    
    
    
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值