zoukankan      html  css  js  c++  java
  • Java--JDBC控制事务

    Java--JDBC控制事务

    博客说明

    文章所涉及的资料来自互联网整理和个人总结,意在于个人学习和经验汇总,如有什么地方侵权,请联系本人删除,谢谢!

    使用Connection对象来管理事务

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

      • 在执行sql之前开启事务
    • 提交事务:commit()

      • 当所有sql都执行完提交事务
    • 回滚事务:rollback()

      • 在catch中回滚事务

    代码

    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);
    	        }
    

    感谢

    百度百科

    以及勤劳的自己

    关注公众号: 归子莫,获取更多的资料,还有更长的学习计划

  • 相关阅读:
    LoadRunner使用记录
    JVM&GC详解
    常用网络操作命令
    IP地址、子网掩码、网络号、主机号、网络地址、主机地址详解
    交换机配置记录
    持续集成与自动化部署---代码流水线管理及Jenkins和gitlab集成
    Git的安装与使用详解
    性能测试---问题记录
    性能测试---实战篇
    c++实用快捷键
  • 原文地址:https://www.cnblogs.com/guizimo/p/13136728.html
Copyright © 2011-2022 走看看