JDBC详解

发布于:2022-12-20 ⋅ 阅读:(332) ⋅ 点赞:(0)

1.JDBC概述

        在开发中我们使用的是java语言,那么势必要通过java语言操作数据库中的数据。而JDBC就可以实现。

1.1JDBC原理

        JDBC是接口,驱动是接口的实现,没有驱动将无法完成数据库连接,从而不能操作数据库!每个数据库厂商都需要提供自己的驱动,用来连接自己公司的数据库,也就是说驱动一般都由数据库生成厂商提供。


 

2.JDBC快速入门

        第一步:编写Java代码

        第二步:Java代码将SQL发送到MySQL服务端

        第三步:MySQL服务端接收到SQL语句并执行该SQL语句

        第四步:将SQL语句执行的结果返回给Java代码

2.1编写代码步骤

1.创建工程,导入驱动jar包

2.注册驱动

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

3.获取连接

        Connection conn = DriverManager.getConnection(url, username, password);

4.定义SQL语句

        String sql =  “update…” ;

5.获取执行SQL对象

        Statement stmt = conn.createStatement();

6.执行SQL

        stmt.executeUpdate(sql);  

7.处理返回结果

8.释放资源

/**
 * JDBC快速入门
 */
public class JDBCDemo {

    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/db1";
        String username = "root";
        String password = "1234";
        Connection conn = DriverManager.getConnection(url, username, password);
        //3. 定义sql
        String sql = "update account set money = 2000 where id = 1";
        //4. 获取执行sql的对象 Statement
        Statement stmt = conn.createStatement();
        //5. 执行sql
        int count = stmt.executeUpdate(sql);//受影响的行数
        //6. 处理结果
        System.out.println(count);
        //7. 释放资源
        stmt.close();
        conn.close();
    }
}

3.JDBC常用API

3.1DriverManager(驱动管理类)

作用:注册驱动

参数说明:        

        url : 连接路径

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

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

        user:用户名

        password:密码

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

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

3.2Connection(数据库连接对象)

作用:1.获取执行 SQL 的对象

           2.管理事务

           3.获取执行SQL对象

Statement createStatement()

通常我们使用PreparedStatement  prepareStatement(sql),因为预编译SQL的执行SQL对象:防止SQL注入。

4.事务管理:

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

* 提交事务 : COMMIT;

* 回滚事务 : ROLLBACK;

> MySQL默认是自动提交事务

/**
 * JDBC API 详解:Connection
 */
public class JDBCDemo3_Connection {

    public static void main(String[] args) throws Exception {
        //1. 注册驱动
        //Class.forName("com.mysql.jdbc.Driver");
        //2. 获取连接:如果连接的是本机mysql并且端口是默认的 3306 可以简化书写
        String url = "jdbc:mysql:///db1?useSSL=false";
        String username = "root";
        String password = "1234";
        Connection conn = DriverManager.getConnection(url, username, password);
        //3. 定义sql
        String sql1 = "update account set money = 3000 where id = 1";
        String sql2 = "update account set money = 3000 where id = 2";
        //4. 获取执行sql的对象 Statement
        Statement stmt = conn.createStatement();

        try {
            // ============开启事务==========
            conn.setAutoCommit(false);
            //5. 执行sql
            int count1 = stmt.executeUpdate(sql1);//受影响的行数
            //6. 处理结果
            System.out.println(count1);
            int i = 3/0;
            //5. 执行sql
            int count2 = stmt.executeUpdate(sql2);//受影响的行数
            //6. 处理结果
            System.out.println(count2);

            // ============提交事务==========
            //程序运行到此处,说明没有出现任何问题,则需求提交事务
            conn.commit();
        } catch (Exception e) {
            // ============回滚事务==========
            //程序在出现异常时会执行到这个地方,此时就需要回滚事务
            conn.rollback();
            e.printStackTrace();
        }

        //7. 释放资源
        stmt.close();
        conn.close();
    }
}

3.3Statement

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

3.4  ResultSet(结果集对象)

作用:封装了SQL查询语句的结果。


  /**
    *需求:查询account账户表数据,封装为Account对象中,并且存储到ArrayList集合中
    * 查询account账户表数据,封装为Account对象中,并且存储到ArrayList集合中
    * 1. 定义实体类Account
    * 2. 查询数据,封装到Account对象中
    * 3. 将Account对象存入ArrayList集合中
    */
  @Test
  public void testResultSet2() throws  Exception {
      //1. 注册驱动
      //Class.forName("com.mysql.jdbc.Driver");
      //2. 获取连接:如果连接的是本机mysql并且端口是默认的 3306 可以简化书写
      String url = "jdbc:mysql:///db1?useSSL=false";
      String username = "root";
      String password = "1234";
      Connection conn = DriverManager.getConnection(url, username, password);
  
      //3. 定义sql
      String sql = "select * from account";
  
      //4. 获取statement对象
      Statement stmt = conn.createStatement();
  
      //5. 执行sql
      ResultSet rs = stmt.executeQuery(sql);
  
      // 创建集合
      List<Account> list = new ArrayList<>();
     
      // 6.1 光标向下移动一行,并且判断当前行是否有数据
      while (rs.next()){
          Account account = new Account();
  
          //6.2 获取数据  getXxx()
          int id = rs.getInt("id");
          String name = rs.getString("name");
          double money = rs.getDouble("money");
  
          //赋值
          account.setId(id);
          account.setName(name);
          account.setMoney(money);
  
          // 存入集合
          list.add(account);
      }
  
      System.out.println(list);
  
      //7. 释放资源
      rs.close();
      stmt.close();
      conn.close();
  }

4.数据库连接池

4.1  数据库连接池简介

  1. 数据库连接池是个容器,负责分配、管理数据库连接(Connection)

  2. 它允许应用程序重复使用一个现有的数据库连接,而不是再重新建立一个

  3. 好处

    *资源重用

         * 提升系统响应速度

之前我们代码中使用连接是没有使用都创建一个Connection对象,使用完毕就会将其销毁。这样重复创建销毁的过程是特别耗费计算机的性能的及消耗时间的,而数据库使用了数据库连接池后,就能达到Connection对象的复用。

原理:连接池是在一开始就创建好了一些连接(Connection)对象存储起来。用户需要连接数据库时,不需要自己创建连接,而只需要从连接池中获取一个连接进行使用,使用完毕后再将连接对象归还给连接池;这样就可以起到资源重用,也节省了频繁创建连接销毁连接所花费的时间,从而提升了系统响应的速度。

4.2数据库连接池实现

        常见的数据库连接池:

                 * DBCP

                 * C3P0

                 * Druid

连接池的使用:

        编写(properties)配置文件如下:

driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql:///db1?useSSL=false&useServerPrepStmts=true
username=root
password=1234
# 初始化连接数量
initialSize=5
# 最大连接数
maxActive=10
# 最大等待时间
maxWait=3000

使用Druid数据库连接池:

public class DruidDemo {

    public static void main(String[] args) throws Exception {
        //1.导入jar包
        //2.定义配置文件
        //3. 加载配置文件
        Properties prop = new Properties();
        prop.load(new FileInputStream("jdbc-demo/src/druid.properties"));
        //4. 获取连接池对象
        DataSource dataSource = DruidDataSourceFactory.createDataSource(prop);

        //5. 获取数据库连接 Connection
        Connection connection = dataSource.getConnection();
        System.out.println(connection); //获取到了连接后就可以继续做其他操作了

        //System.out.println(System.getProperty("user.dir"));
    }
}


网站公告

今日签到

点亮在社区的每一天
去签到