zoukankan      html  css  js  c++  java
  • JDBC

    JDBC

    JDBC

    概念

    Java DataBase Connectivity Java 数据库连接, Java语言操作数据库。

    JDBC本质:其实是官方(sun公司)定义的一套操作所有关系型数据库的规则,即接口。各个数据库厂商去实现这套接口,提供数据库驱动jar包。我们可以使用这套接口(JDBC)编程,真正执行的代码是驱动jar包中的实现类。

    步骤

    1. 导入驱动jar包 mysql-connector-java-5.1.37-bin.jar

      1. 复制mysql-connector-java-5.1.37-bin.jar到项目的libs目录下

      2. 右键-->Add As Library

    2. 注册驱动

    3. 获取数据库连接对象 Connection

    4. 定义sql

    5. 获取执行sql语句的对象 Statement

    6. 执行sql,接受返回结果

    7. 处理结果

    8. 释放资源

    代码实现

     1 public class Demo01 {
     2     public static void main(String[] args) throws Exception {
     3         // 注册驱动
     4         Class.forName("com.mysql.jdbc.Driver");
     5         // 获取数据库连接对象
     6         Connection coon = DriverManager.getConnection("jdbc:mysql://localhost:3306/db3", "root", "root");
     7         // 定义sql语句
     8         String sql = "update student set age=55 where id = 1";
     9         // 获取执行sql的对象 Statement
    10         Statement stem = coon.createStatement();
    11         // 执行sql
    12         int i = stem.executeUpdate(sql);
    13         // 处理结果
    14         System.out.println(i);
    15         // 释放资源
    16         stem.close();
    17         coon.close();
    18     }
    19 }

    详解各个对象

    DriverManager:驱动管理对象

    功能

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

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

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

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

    1 static {
    2     try {
    3         DriverManager.registerDriver(new Driver());
    4     } catch (SQLException var1) {
    5         throw new RuntimeException("Can't register driver!");
    6     }
    7 }

    注意:mysql5之后的驱动jar包可以省略注册驱动的步骤。

    获取数据库连接:

    方法:static Connection getConnection(String url, String user, String password)

    参数:

    • url:指定连接的路径

      • 语法:jdbc:mysql://ip地址(域名):端口号/数据库名称

      • 例子:jdbc:mysql://localhost:3306/db3

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

    • user:用户名

    • password:密码


    Connection:数据库连接对象

    功能

    • 获取执行sql 的对象

      • Statement createStatement()

      • PreparedStatement prepareStatement(String sql)

    • 管理事务

      • 开启事务:setAutoCommit(boolean autoCommit) :调用该方法设置参数为false,即开启事务

      • 提交事务:commit()

      • 回滚事务:rollback()


    Statement:执行sql的对象

    执行sql

    • boolean execute(String sql) :可以执行任意的sql 了解

    • int executeUpdate(String sql) :执行DML(insert、update、delete)语句、DDL(create,alter、drop)语句

    返回值:影响的行数,可以通过这个影响的行数判断DML语句是否执行成功 返回值>0的则执行成功,反之,则失败。

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


    ResultSet:结果集对象,封装查询结果

    boolean next(): 游标向下移动一行,判断当前行是否是最后一行末尾(是否有数据),如果是,则返回false,如果不是则返回true

    getXxx(参数):获取数据

    • Xxx:代表数据类型 如: int getInt() , String getString()

    参数:

    • int:代表列的编号,从1开始 如: getString(1)

    • String:代表列名称。 如: getDouble("balance")

    注意:

    1. 游标向下移动一行

    2. 判断是否有数据

    3. 获取数据

    //循环判断游标是否是最后一行末尾。
    1 while(rs.next()){
    2     //获取数据
    3     int id = rs.getInt(1);
    4     String name = rs.getString("name");
    5     double balance = rs.getDouble(3);
    6 7     System.out.println(id + "---" + name + "---" + balance);
    8 }

    抽取JDBC工具类 : JDBCUtils

    目的:简化书写

    分析:

    1. 注册驱动也抽取

    2. 抽取一个方法获取连接对象

      • 需求:不想传递参数(麻烦),还得保证工具类的通用性。

      • 解决:配置文件

      url=
      user=
      password=
    3. 抽取一个方法释放资源

       1 public class JdbcUtils {
       2     // 定义静态成员变量
       3     private static String url;
       4     private static String user;
       5     private static String password;
       6     private static String driver;
       7  8     static {
       9         // 读取资源文件,获取值
      10         try {
      11             // 创建Properties集合类
      12             Properties pro = new Properties();
      13             // 加载文件
      14             ClassLoader classLoader = JdbcUtils.class.getClassLoader();
      15             URL resource = classLoader.getResource("jdbc.properties");
      16             String path = resource.getPath();
      17             // System.out.println(path);
      18 19             pro.load(new FileReader(path));
      20             // pro.load(new FileReader("src/jdbc.properties"));
      21             // 获取数据,赋值
      22             url = pro.getProperty("url");
      23             user = pro.getProperty("user");
      24             password = pro.getProperty("password");
      25             driver = pro.getProperty("driver");
      26             // 注册驱动
      27             Class.forName(driver);
      28 29         } catch (IOException e) {
      30             e.printStackTrace();
      31         } catch (ClassNotFoundException e) {
      32             e.printStackTrace();
      33         }
      34 35     }
      36 37 38     public static Connection getConnection() throws SQLException {
      39         return DriverManager.getConnection(url, user, password);
      40     }
      41 42     public static void close(Statement statement, Connection connection) {
      43         if (statement != null) {
      44             try {
      45                 statement.close();
      46             } catch (SQLException e) {
      47                 e.printStackTrace();
      48             }
      49         }
      50         if (connection != null) {
      51             try {
      52                 connection.close();
      53             } catch (SQLException e) {
      54                 e.printStackTrace();
      55             }
      56         }
      57     }
      58 59     public static void close(ResultSet resultSet, Statement statement, Connection connection) {
      60         if (resultSet != null) {
      61             try {
      62                 resultSet.close();
      63             } catch (SQLException e) {
      64                 e.printStackTrace();
      65             }
      66         }
      67         if (statement != null) {
      68             try {
      69                 statement.close();
      70             } catch (SQLException e) {
      71                 e.printStackTrace();
      72             }
      73         }
      74         if (connection != null) {
      75             try {
      76                 connection.close();
      77             } catch (SQLException e) {
      78                 e.printStackTrace();
      79             }
      80         }
      81     }
      82 }

    JDBC控制事务:

    1. 事务:一个包含多个步骤的业务操作。如果这个业务操作被事务管理,则这多个步骤要么同时成功,要么同时失败。

    2. 操作:

      • 开启事务

      • 提交事务

      • 回滚事务

    3. 使用Connection对象来管理事务

      • 开启事务:setAutoCommit(boolean autoCommit) :调用该方法设置参数为false,即开启事务

        • 在执行sql之前开启事务

      • 提交事务:commit()

        • 当所有sql都执行完提交事务

      • 回滚事务:rollback()

        • 在catch中回滚事务

     1 public class JDBCDemo10 {
     2  3     public static void main(String[] args) {
     4         Connection conn = null;
     5         PreparedStatement pstmt1 = null;
     6         PreparedStatement pstmt2 = null;
     7  8         try {
     9             //1.获取连接
    10             conn = JDBCUtils.getConnection();
    11             //开启事务
    12             conn.setAutoCommit(false);
    13 14             //2.定义sql
    15             //2.1 张三 - 500
    16             String sql1 = "update account set balance = balance - ? where id = ?";
    17             //2.2 李四 + 500
    18             String sql2 = "update account set balance = balance + ? where id = ?";
    19             //3.获取执行sql对象
    20             pstmt1 = conn.prepareStatement(sql1);
    21             pstmt2 = conn.prepareStatement(sql2);
    22             //4. 设置参数
    23             pstmt1.setDouble(1, 500);
    24             pstmt1.setInt(2, 1);
    25 26             pstmt2.setDouble(1, 500);
    27             pstmt2.setInt(2, 2);
    28             //5.执行sql
    29             pstmt1.executeUpdate();
    30             // 手动制造异常
    31             int i = 3 / 0;
    32 33             pstmt2.executeUpdate();
    34             //提交事务
    35             conn.commit();
    36         } catch (Exception e) {
    37             //事务回滚
    38             try {
    39                 if (conn != null) {
    40                     conn.rollback();
    41                 }
    42             } catch (SQLException e1) {
    43                 e1.printStackTrace();
    44             }
    45             e.printStackTrace();
    46         } finally {
    47             JDBCUtils.close(pstmt1, conn);
    48             JDBCUtils.close(pstmt2, null);
    49         }
    50     }
    51 52 }

     

     

  • 相关阅读:
    SSH框架总结(框架分析+环境搭建+实例源码下载)(转)
    用PowerMockito来mock私有方法(转)
    Mockito简介(转)
    统治世界的十大算法
    ThreadLocal用法和实现原理(转)
    在Eclipse中使用JUnit4进行单元測试(0基础篇)
    libgdx, mouse 关节
    sprintf,你知道多少?
    北京簋街 美食全然攻略 + 簋街好吃的夜宵去处-----店铺介绍大全
    codeforces-148D-Bag of mice-概率DP
  • 原文地址:https://www.cnblogs.com/lx-pricking/p/12709780.html
Copyright © 2011-2022 走看看