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

    感谢

    百度百科

    以及勤劳的自己

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

  • 相关阅读:
    常见浏览器的兼容问题
    SCSS 的理解
    常见浏览器兼容性问题与解决方案(上)
    常见浏览器兼容性问题与解决方案(下)
    ie6定位absolute bug触发layout解决
    AngularJS 最常用的八种功能
    IE6的3像素bug
    CSS属性级Hack
    什么是SASS
    什么是less?
  • 原文地址:https://www.cnblogs.com/guizimo/p/13136728.html
Copyright © 2011-2022 走看看