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文档生成与维护方法
上一篇:Mac如何恢复误删的照片_Mac照片应用最近删除找回
下一篇:Linux权限介绍
上一篇:Mac如何恢复误删的照片_Mac照片应用最近删除找回
下一篇:Linux权限介绍

