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系统配置与自定义日志通道
上一篇:Mac如何恢复误删的照片_Mac照片应用最近删除找回
下一篇:Linux权限介绍
上一篇:Mac如何恢复误删的照片_Mac照片应用最近删除找回
下一篇:Linux权限介绍

