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


相关推荐: 在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  百度浏览器网页无法复制文字怎么办 百度浏览器复制修复  如何在万网自助建站中设置域名及备案?  Laravel怎么返回JSON格式数据_Laravel API资源Response响应格式化【技巧】  JavaScript如何实现路由_前端路由原理是什么  Swift开发中switch语句值绑定模式  微信h5制作网站有哪些,免费微信H5页面制作工具?  动图在线制作网站有哪些,滑动动图图集怎么做?  如何在IIS中新建站点并解决端口绑定冲突?  C#如何调用原生C++ COM对象详解  Laravel全局作用域是什么_Laravel Eloquent Global Scopes应用指南  php json中文编码为null的解决办法  Android仿QQ列表左滑删除操作  如何快速登录WAP自助建站平台?  如何快速搭建高效香港服务器网站?  黑客入侵网站服务器的常见手法有哪些?  Laravel如何使用Guzzle调用外部接口_Laravel发起HTTP请求与JSON数据解析【详解】  javascript读取文本节点方法小结  Laravel如何实现用户角色和权限系统_Laravel角色权限管理机制  微信小程序 require机制详解及实例代码  java中使用zxing批量生成二维码立牌  如何在 Python 中将列表项按字母顺序编号(a.、b.、c. …)  Laravel Livewire是什么_使用Laravel Livewire构建动态前端界面  Laravel如何设置定时任务(Cron Job)_Laravel调度器与任务计划配置  香港服务器网站卡顿?如何解决网络延迟与负载问题?  简单实现Android验证码  魔毅自助建站系统:模板定制与SEO优化一键生成指南  Swift中switch语句区间和元组模式匹配  如何在 React 中条件性地遍历数组并渲染元素  大学网站设计制作软件有哪些,如何将网站制作成自己app?  高端企业智能建站程序:SEO优化与响应式模板定制开发  JavaScript模板引擎Template.js使用详解  如何用景安虚拟主机手机版绑定域名建站?  如何利用DOS批处理实现定时关机操作详解  微信小程序 scroll-view组件实现列表页实例代码  如何在VPS电脑上快速搭建网站?  如何制作一个表白网站视频,关于勇敢表白的小标题?  如何在云主机上快速搭建网站?  微信小程序 wx.uploadFile无法上传解决办法  JavaScript如何实现倒计时_时间函数如何精确控制  Laravel中间件起什么作用_Laravel Middleware请求生命周期与自定义详解  如何快速搭建虚拟主机网站?新手必看指南  网易LOFTER官网链接 老福特网页版登录地址  Python文件流缓冲机制_IO性能解析【教程】  Laravel怎么实现前端Toast弹窗提示_Laravel Session闪存数据Flash传递给前端【方法】  Laravel怎么多语言本地化设置_Laravel语言包翻译与Locale动态切换【手册】  谷歌浏览器如何更改浏览器主题 Google Chrome主题设置教程  Laravel如何使用Eloquent进行子查询  Win11摄像头无法使用怎么办_Win11相机隐私权限开启教程【详解】  Laravel如何为API编写文档_Laravel API文档生成与维护方法