java回滚,java回滚操作

本文目录一览:

java中jdbc多表操作如何事物回滚

可以把要执行的四个SQL语句写到同一个List中再调用此方法

你也可以自己写

主要注意

执行sql插入前要取消自动提交

con.setAutoCommit(false);

全部sql语句执行完成后再提交

con.commit();

执行过程抛出异常则回滚

con.rollback();

希望对你有帮助

public

boolean

exeupdate(ListString

sqls)

throws

SQLException

{

boolean

flag

=

false;

openPoolConnection();//创建连接

try

{

//

con.setAutoCommit(false);//取消自动提交

for(int

i=0;isqls.size();i++)

{

pstmt

=

con.prepareStatement(sqls.get(i));

int

rows

=

pstmt.executeUpdate();

}

flag

=

true;

con.commit();//提交

}

catch

(Exception

e)

{

con.rollback();//回滚

e.printStackTrace();

}

finally

{

this.closeAll();//关闭连接

数据集

语句对象

}

return

flag;

}

在Java中事物的提交和回滚是什么意思?

向数据库提交数据或修改数据,如果你觉得没有问题,就可以提交,如果其中有一个环节出错了,就可以设置回滚,可以根据判断进行回滚,不是非要出异常了才回滚,如何回滚如何提交要看你的业务逻辑。

比如:

你去银行转账,转账我们有两步吧,从你账户中取出钱再往他账户中加钱。那这两步银行是必须要确保正确无误的进行的。要被看做成一个事务。其中任何一步出错就算是转账失败,但可能你这时是已经从你账户中扣了钱了,又没往他账户里加钱,怎么办?银行会事务回滚,不保存你刚才的操作,即恢复到你没转账之前的状态。

请教:如何在java程序中实现数据操作的“回滚”

–事务处理:

begin tran –开始处理数据时,开启事务

–下面是具体的处理语句

insert into 表 values(1)

if @@error0 –如果处理语句出错,回滚事务

begin

rollback tran

goto lbexit

end

update 表 set 字段=1

if @@error0 –如果处理语句出错,回滚事务

begin

rollback tran

goto lbexit

end

commit tran –所有执行成功,提交事务

lbexit:

JAVA的话,可以在连接对象上启用事务

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/183354.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-11-24 16:28
下一篇 2024-11-24 16:29

相关推荐

  • Java JsonPath 效率优化指南

    本篇文章将深入探讨Java JsonPath的效率问题,并提供一些优化方案。 一、JsonPath 简介 JsonPath是一个可用于从JSON数据中获取信息的库。它提供了一种DS…

    编程 2025-04-29
  • java client.getacsresponse 编译报错解决方法

    java client.getacsresponse 编译报错是Java编程过程中常见的错误,常见的原因是代码的语法错误、类库依赖问题和编译环境的配置问题。下面将从多个方面进行分析…

    编程 2025-04-29
  • Java Bean加载过程

    Java Bean加载过程涉及到类加载器、反射机制和Java虚拟机的执行过程。在本文中,将从这三个方面详细阐述Java Bean加载的过程。 一、类加载器 类加载器是Java虚拟机…

    编程 2025-04-29
  • Java腾讯云音视频对接

    本文旨在从多个方面详细阐述Java腾讯云音视频对接,提供完整的代码示例。 一、腾讯云音视频介绍 腾讯云音视频服务(Cloud Tencent Real-Time Communica…

    编程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介绍

    本文将详细介绍Java Milvus SearchParam withoutFields的相关知识和用法。 一、什么是Java Milvus SearchParam without…

    编程 2025-04-29
  • Python栈操作用法介绍

    如果你是一位Python开发工程师,那么你必须掌握Python中的栈操作。在Python中,栈是一个容器,提供后进先出(LIFO)的原则。这篇文章将通过多个方面详细地阐述Pytho…

    编程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java语言中的一个版本,于2014年3月18日发布。本文将从多个方面对Java 8中某一周的周一进行详细的阐述。 一、数组处理 Java 8新特性之一是Stream…

    编程 2025-04-29
  • Java判断字符串是否存在多个

    本文将从以下几个方面详细阐述如何使用Java判断一个字符串中是否存在多个指定字符: 一、字符串遍历 字符串是Java编程中非常重要的一种数据类型。要判断字符串中是否存在多个指定字符…

    编程 2025-04-29
  • VSCode为什么无法运行Java

    解答:VSCode无法运行Java是因为默认情况下,VSCode并没有集成Java运行环境,需要手动添加Java运行环境或安装相关插件才能实现Java代码的编写、调试和运行。 一、…

    编程 2025-04-29
  • Java任务下发回滚系统的设计与实现

    本文将介绍一个Java任务下发回滚系统的设计与实现。该系统可以用于执行复杂的任务,包括可回滚的任务,及时恢复任务失败前的状态。系统使用Java语言进行开发,可以支持多种类型的任务。…

    编程 2025-04-29

发表回复

登录后才能评论