zoukankan      html  css  js  c++  java
  • MySql数据库事务正常提交,回滚失败

    • 问题:在初次练习Mysql数据库事务时,事务正常提交,但是在遇到异常应当回滚时,回滚失败。

    代码如下:

    //2.更新操作。
    public void update(Connection conn, String sql, Object ...objects){
            PreparedStatement preparedstatement = null;
            try {
                preparedstatement = conn.prepareStatement(sql);
                for(int i = 0; i < objects.length; i++){
                    preparedstatement.setObject(i + 1, objects[i]);
                }
                preparedstatement.executeUpdate();
            } catch (Exception e) {
                e.printStackTrace();
            }finally{
                TestTools.release(preparedstatement,null);
            }
        }
        /**
         * 2_1.测试以上方法
         */
        @Test
        public void test(){
            Connection conn = null;
            try {
                conn = TestTools.getConnection();
                //开始事务,在开始之前要关闭数据库默认自动提交
                conn.setAutoCommit(false);
    
                String sql = "update users set  balance = balance - 500 where id = 1";
                update(conn,sql);
                //出现异常时,事务回滚到之前的状态
                int number = 10 / 0;
                System.out.println(number);
    
                sql = "update users set  balance = balance + 500 where id = 2";
                update(conn,sql);
                //结束,就提交事务
                conn.commit();
    
            } catch (Exception e) {
                e.printStackTrace();
                //发生异常,事务回滚
                try {
                    conn.rollback();
                } catch (SQLException e1) {
                    e1.printStackTrace();
                }
            }finally{
                //设置事务提交方式为自动提交:
                try {
                    conn.setAutoCommit(true);
                } catch (SQLException e) {
                    e.printStackTrace();
                }
                //关闭连接
                TestTools.release(null, conn);
            }
        }
    结果应当是遇到异常事务回滚,但结果是id1balance的值被减去500,事务遇到异常没有回滚。
    • 原因:Mysql数据库引擎使用的是默认的MyISAM,mysql支持四种引擎,如下图
      这里写图片描述

    从图中可以看出mysql默认的引擎并不支持事务。

    • 解决方法:修改表引擎

    修改某个表的存储引擎为innodb:alter table table_name engine=innodb;
    注意:修改或者操作某个表之前首先要进入某个表所在的数据库中,使用use db_name go;,之后再进行增删改查操作。

    其他查看mysql引擎相关信息的sql语句:

    1.查看系统支持的存储引擎:show engines;
    2.查看表使用的存储引擎
    两种方法:
     a、show table status from db_name where name='table_name';
     b、show create table table_name;
    3.mysql当前默认的存储引擎:show variables like '%storage_engine%';
    4.某个表用了什么引擎:show create table 表名;
  • 相关阅读:
    数据库 | 建表常用语句
    心得 | 撰写项目申报书
    工具 | 时间转化
    SpringBoot | 启动异常 | 显示bulid success 无 error信息
    120. 三角形最小路径和
    63. 不同路径 II
    SpringBoot | Velocity template
    SpringBoot | quartz | @DisallowConcurrentExecution
    SpringBoot | Hibernate @Transient 注解
    Java | 基础归纳 | 静态方法与实例方法的区别
  • 原文地址:https://www.cnblogs.com/tengpengfei/p/10454018.html
Copyright © 2011-2022 走看看