Java--JDBC控制事务

协变苔藓
• 阅读 1398

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

    感谢

    百度百科

    以及勤劳的自己

    点赞
    收藏
    评论区
    推荐文章
    Johnny21 Johnny21
    4年前
    运维安全-信息安全
    本文转自,如有侵权,请联系删除。
    Wesley13 Wesley13
    3年前
    Java项目笔记之知识点总结03
    不点蓝字,我们哪来故事?SSM本质是Spring去集成SpringMVC和MyBatis,即控制器对象、业务对象、Mapper对象等都交由Spring容器管理,使用SpringIoC和DI来完成对象创建及其属性注入,使用AOP来配置事务。作用是在框架上基础上开发,发挥各
    Stella981 Stella981
    3年前
    Spring 事务失效的 8 大场景,面试官直呼666...
    !(https://oscimg.oschina.net/oscnet/c5b4fcf737f248db8060e0f7c009f6c8.jpg)前几天发了一篇文章里面有一个关于事务失效的问题:用Spring的@Transactional注解控制事务有哪些不生效的场景?其中有个热心粉丝留言分享了下,我觉得总结得有点经验
    Stella981 Stella981
    3年前
    IntelliJ IDEA 2020最新版本可用,有图有真相!
    「版权声明」:本教程只做个人学习使用,请勿用于商业用途!如需商业版本,请前往下面官方地址购买,版权归属权为JetBranins公司!资源收集于网络,如有侵权请联系作者删除。若资金允许,请点击 https://www.jetbrains.com/idea/buy/(https://www.oschina.net/action/GoToL
    Wesley13 Wesley13
    3年前
    IDEA 激活码,IDEA 注册码,IDEA 2019.3 激活码
    https://www.cnblogs.com/souyunku/archive/2020/03/04/12405977.html申明:本教程IntelliJIDEA2019.3激活方式均收集于网络,请勿商用,仅供个人学习使用,如有侵权,请联系作者删除。注意:激活,可到2089年本教程理论
    Wesley13 Wesley13
    3年前
    CTF
    CTFPwn\BJDCTF2nd\r2t4博客说明文章所涉及的资料来自互联网整理和个人总结,意在于个人学习和经验汇总,如有什么地方侵权,请联系本人删除,谢谢!本文仅用于学习与交流,不得用于非法用途!CTP平台网址https://buuoj.cn/cha
    Wesley13 Wesley13
    3年前
    mysql设置时区
    mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
    Wesley13 Wesley13
    3年前
    MySQL数据库InnoDB存储引擎Log漫游(1)
    作者:宋利兵来源:MySQL代码研究(mysqlcode)0、导读本文介绍了InnoDB引擎如何利用UndoLog和RedoLog来保证事务的原子性、持久性原理,以及InnoDB引擎实现UndoLog和RedoLog的基本思路。00–UndoLogUndoLog是为了实现事务的原子性,
    Stella981 Stella981
    3年前
    Electron整合React使用搭建开发环境
    Electron整合React使用搭建开发环境博客说明文章所涉及的资料来自互联网整理和个人总结,意在于个人学习和经验汇总,如有什么地方侵权,请联系本人删除,谢谢!简介用于构建用户界面的JavaScript库步骤首先创建React
    Wesley13 Wesley13
    3年前
    Mysql事务处理
    事务处理在各种管理系统中都有着广泛的应用,比如人员管理系统,很多同步数据库操作大都需要用到事务处理。比如说,在人员管理系统中,你删除一个人员,你即需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这样,这些数据库操作语句就构成一个事务!   删除的SQL语句deletefromuserinfowhere~~~d
    Wesley13 Wesley13
    3年前
    mysql事务隔离
    事务MySQL事务主要用于处理操作量大,复杂度高的数据。比如:在人员管理系统中,你删除一个人员,你即需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这样,这些数据库操作语句就构成一个事务!特性一般来说,事务是必须满足4个条件(ACID):原子性(Atomicity,或称不可分割性)、一致性(Consis