Mysql事务操作失败如何解决

发布时间 - 2026-01-11 02:18:27    点击率:

Mysql事务操作失败如何解决

事务的原子性 :事务是数据库的逻辑工作单位,事务中包含的各操作要么都做,要么都不做 。

要实现事务的原子性,单单靠一条commit或是rollback命令还是不行的,因为例如commit命令它只是将一个事务中执行成功的DML语句提交给数据库里。如果要实现事务的原子性,则就需要commit和rollback命令配合上程序上的一个业务逻辑才能可以,具体业务逻辑代码如下示例代码:

1.现象

     程序中打开了事务进行插入,但是没有commit,表中的数据已经存在,就是回滚也不能删除插入的数据

2.原因

    本表的Storage Engine 为myisam,不是innoDB,不支持事务处理 rollback()

3.解决方法

    使用 alter table xxxx engine = innoDB ; 将表改为 InnoDB 引擎,结果回滚正常。

4.代码

 private void testCrud() {
     Connection conn = null;      //连接对象
     PreparedStatement pstmt = null;  //预编译的SQL语句对象
      try{
        //加载MySQL驱动程序
        Class.forName("com.mysql.jdbc.Driver");
        //连接字符串
        String url = "jdbc:mysql://localhost:3306/test";
        //建立数据库连接
        conn = DriverManager.getConnection(url,"root","");
        //设置事务的隔离级别
        // conn.setTransactionIsolation(Connection. TRANSACTION_REPEATABLE_READ);
        //设置自动提交为false,开始事务
        conn.setAutoCommit(false);
        //带参数的更新语句
        String sql = "INSERT INTO user_info (username ,password ,age )values(?,?,?)";
        //准备语句
        pstmt = conn.prepareStatement(sql);
        //绑定参数,执行更新语句,将张三的账户金额减去1000元
        pstmt.setString(1, "zhangui");
        pstmt.setString(2, "1111");
        pstmt.setInt(3, 300);
        pstmt.execute();
        
        //绑定参数,执行更新语句,将李四的账户金额增加1000元
        // pstmt.setString(1, "zzzzzzzzzzzzzzzzz"); //绑定了非法参数
        //pstmt.setString(2, "1111111111");
        //pstmt.setInt(3, 500);
        //pstmt.execute(); //将抛出SQL异常
        //提交事务
        //conn.commit();
        System.out.println("事务已提交,转账成功!");
        //关闭语句、连接
        pstmt.close(); conn.close();
      }catch(Exception e){
        try{
          conn.rollback();  //回滚事务
          System.out.println("事务回滚成功,没有任何记录被更新!");
        }catch(Exception re){
          System.out.println("回滚事务失败!");
        }
        e.printStackTrace();
      }finally{
        if(pstmt!=null) try{pstmt.close();}catch(Exception ignore){}
        if(conn!=null) try{conn.close();}catch(Exception ignore){}
      }
    
  }

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# Mysql事务操作失败  # mysql  # 事务操作失败解决办法  # Mysql事务处理详解  # 通过实例分析MySQL中的四种事务隔离级别  # 解决Mysql收缩事务日志和日志文件过大无法收缩问题  # mysql的存储过程、游标 、事务实例详解  # PHP mysqli事务操作常用方法分析  # MySQL四种事务隔离级别详解  # NodeJs使用Mysql模块实现事务处理实例  # MySQL数据库事务隔离级别详解  # MySQL事务的基础学习以及心得分享  # 绑定  # 没有任何  # 希望能  # 不做  # 不支持  # 谢谢大家  # 定了  # 解决方法  # 都做  # 如何解决  # 抛出  # 设置自动  # 单靠  # 库里  # 事务处理  # 李四  # 加载  # 本表  # 打开了  # brush 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 夸克浏览器网页跳转延迟怎么办 夸克浏览器跳转优化  JavaScript如何操作视频_媒体API怎么控制播放  专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?  网站页面设计需要考虑到这些问题  Laravel如何实现API版本控制_Laravel API版本化路由设计策略  JavaScript如何实现倒计时_时间函数如何精确控制  太平洋网站制作公司,网络用语太平洋是什么意思?  如何确保FTP站点访问权限与数据传输安全?  Python3.6正式版新特性预览  js实现获取鼠标当前的位置  北京专业网站制作设计师招聘,北京白云观官方网站?  Linux后台任务运行方法_nohup与&使用技巧【技巧】  如何确保西部建站助手FTP传输的安全性?  Win11任务栏卡死怎么办 Windows11任务栏无反应解决方法【教程】  网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?  Laravel安装步骤详细教程_Laravel环境搭建指南  济南网站建设制作公司,室内设计网站一般都有哪些功能?  详解Oracle修改字段类型方法总结  ,怎么在广州志愿者网站注册?  网站制作价目表怎么做,珍爱网婚介费用多少?  敲碗10年!Mac系列传将迎来「触控与联网」双革新  高防服务器:AI智能防御DDoS攻击与数据安全保障  北京网站制作的公司有哪些,北京白云观官方网站?  如何自定义safari浏览器工具栏?个性化设置safari浏览器界面教程【技巧】  如何在云主机快速搭建网站站点?  Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转  三星、SK海力士获美批准:可向中国出口芯片制造设备  如何快速查询网站的真实建站时间?  Python图片处理进阶教程_Pillow滤镜与图像增强  如何用wdcp快速搭建高效网站?  通义万相免费版怎么用_通义万相免费版使用方法详细指南【教程】  如何登录建站主机?访问步骤全解析  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  奇安信“盘古石”团队突破 iOS 26.1 提权  打造顶配客厅影院,这份100寸电视推荐名单请查收  java ZXing生成二维码及条码实例分享  猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?  浅谈javascript alert和confirm的美化  php静态变量怎么调试_php静态变量作用域调试技巧【解答】  如何做网站制作流程,*游戏网站怎么搭建?  Laravel定时任务怎么设置_Laravel Crontab调度器配置  iOS发送验证码倒计时应用  Laravel如何实现登录错误次数限制_Laravel自带LoginThrottles限流配置【方法】  jimdo怎样用html5做选项卡_jimdo选项卡html5实现与切换效果【指南】  Internet Explorer官网直接进入 IE浏览器在线体验版网址  如何在云主机上快速搭建网站?  电视网站制作tvbox接口,云海电视怎样自定义添加电视源?  猎豹浏览器开发者工具怎么打开 猎豹浏览器F12调试工具使用【前端必备】  Laravel模型事件有哪些_Laravel Model Event生命周期详解  Laravel如何记录日志_Laravel Logging系统配置与自定义日志通道