JDBC+JDBC控制事务(复习总结)

tech2022-08-12  134

概念:Java DataBase Connectivity  Java 数据库连接, Java语言操作数据库;

    * 步骤:         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. 导入驱动jar包 //2.注册驱动 Class.forName("com.mysql.jdbc.Driver"); //3.获取数据库连接对象 Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/db3", "root", "root"); //4.定义sql语句 String sql = "update account set balance = 500 where id = 1"; //5.获取执行sql的对象 Statement Statement stmt = conn.createStatement(); //6.执行sql int count = stmt.executeUpdate(sql); //7.处理结果 System.out.println(count); //8.释放资源 stmt.close(); conn.close();

Connection:数据库连接对象

        1. 功能:             1. 获取执行sql 的对象                 * Statement createStatement()                 * PreparedStatement prepareStatement(String sql)               2. 管理事务:                 * 开启事务:setAutoCommit(boolean autoCommit) :调用该方法设置参数为false,即开启事务                 * 提交事务:commit()                  * 回滚事务:rollback()      3. Statement:执行sql的对象         1. 执行sql             1. boolean execute(String sql) :可以执行任意的sql              2. int executeUpdate(String sql) :执行DML(insert、update、delete)语句、DDL(create,alter、drop)语句                 * 返回值:影响的行数,可以通过这个影响的行数判断DML语句是否执行成功 返回值>0的则执行成功,反之,则失败。             3. ResultSet executeQuery(String sql)  :执行DQL(select)语句

4. ResultSet:结果集对象,封装查询结果         * boolean next(): 游标向下移动一行,判断当前行是否是最后一行末尾(是否有数据),如果是,则返回false,如果不是则返回true         * getXxx(参数):获取数据             * Xxx:代表数据类型   如: int getInt() ,    String getString()             * 参数:                 1. int:代表列的编号,从1开始   如: getInt(1)                 2. String:代表列名称。 如: getString("name")                  * 注意:             * 使用步骤:                 1. 游标向下移动一行                 2. 判断是否有数据                 3. 获取数据

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

    5. PreparedStatement:执行sql的对象         1. SQL注入问题:在拼接sql时,有一些sql的特殊关键字参与字符串的拼接。会造成安全性问题             1. 输入用户随便,输入密码:a' or 'a' = 'a             2. sql:select * from user where username = 'fhdsjkf' and password = 'a' or 'a' = 'a' 

        2. 解决sql注入问题:使用PreparedStatement对象来解决         3. 预编译的SQL:参数使用?作为占位符         4. 步骤:             1. 导入驱动jar包 mysql-connector-java-5.1.37-bin.jar             2. 注册驱动             3. 获取数据库连接对象 Connection             4. 定义sql                 * 注意:sql的参数使用?作为占位符。 如:select * from user where username = ? and password = ?;             5. 获取执行sql语句的对象 PreparedStatement  Connection.prepareStatement(String sql)              6. 给?赋值:                 * 方法: setXxx(参数1,参数2)                     * 参数1:?的位置编号 从1 开始                     * 参数2:?的值             7. 执行sql,接受返回结果,不需要传递sql语句             8. 处理结果             9. 释放资源

        5. 注意:后期都会使用PreparedStatement来完成增删改查的所有操作             1. 可以防止SQL注入             2. 效率更高

JDBC控制事务:

使用Connection对象来管理事务     * 开启事务:setAutoCommit(boolean autoCommit) :调用该方法设置参数为false,即开启事务         * 在执行sql之前开启事务     * 提交事务:commit()          * 当所有sql都执行完提交事务     * 回滚事务:rollback()          * 在catch中回滚事务

public class JDBCDemo10 { public static void main(String[] args) { Connection conn = null; PreparedStatement pstmt1 = null; PreparedStatement pstmt2 = null; try { //1.获取连接 conn = JDBCUtils.getConnection(); //开启事务 conn.setAutoCommit(false); //2.定义sql //2.1 张三 - 500 String sql1 = "update account set balance = balance - ? where id = ?"; //2.2 李四 + 500 String sql2 = "update account set balance = balance + ? where id = ?"; //3.获取执行sql对象 pstmt1 = conn.prepareStatement(sql1); pstmt2 = conn.prepareStatement(sql2); //4. 设置参数 pstmt1.setDouble(1,500); pstmt1.setInt(2,1); pstmt2.setDouble(1,500); pstmt2.setInt(2,2); //5.执行sql pstmt1.executeUpdate(); // 手动制造异常 int i = 3/0; pstmt2.executeUpdate(); //提交事务 conn.commit(); } catch (Exception e) { //事务回滚 try { if(conn != null) { conn.rollback(); } } catch (SQLException e1) { e1.printStackTrace(); } e.printStackTrace(); }finally { JDBCUtils.close(pstmt1,conn); JDBCUtils.close(pstmt2,null); }

 

最新回复(0)