java 事务_JAVA基础之事务

本文介绍了Java中的事务操作,包括MySQL的默认和手动事务处理,以及JDBC和DBUtils的事务管理。强调了在进行事务控制时,必须确保开启事务和执行SQL的连接是同一个。最后提到了事务的ACID特性。
摘要由CSDN通过智能技术生成

世界万事无简单一说, 每个事情基本上由多个小的事情来完成。有的事情会存在若小的事情不能同时完成的情况就取消所有的小的事情,直至都完成达到预期的效果才算完成!这样就用到了事务操作。在所有的sql语句完成之前,若发生异常,则让事务回滚到开始事务的时候,让事务结束;并且让已执行的sql语句作废。但是连接数据库的connnection与开启事务的connnection必须是一个。这样原来在dao层开启连接必须到service层一起执行了开启事务和处理异常。

一、事务:

一件事情有n个组成单元 :要不这n个组成单元同时成功, 要不n个单元就同时失败。就是将n个组成单元放到一个事务中!

二、mysql事务:

1、默认的事务:一条sql语句就是一个事务 。默认就开启事务并提交事务!

2、手动事务:

①、显示的开启一个事务:start transaction

此时进行的所有的修改都是内存里修改的,具体数据库内到底修改了没还是由是否提交来决定的!!!

当提交了就代表数据库修改了,当回滚了则没有修改!

但是需要注意的是无论数据库到底修改了没有,只要执行了SQL语句,在库内的表里的自增的序号会自动被占用了!!!

②、事务提交:commit

代表从开启事务到事务提交中间的所有的sql都认为有效! 真正的更新数据库!

③、事务的回滚:rollback

代表事务的回滚--在其之前的所有的操作都作废了!回滚到start的地方,同时当前的事务结束了!

014cac9d26cb5cf8555635b6985ef373.png

9222b8feedd39f30d1eb55f5130f668a.png

三、JDBC事务操作:

1、默认是自动事务:

执行sql语句:executeUpdate()  ---- 每执行一次executeUpdate方法 代表 事务自动提交(默认)

2、通过jdbc的API手动事务:

①、开启事务:conn.setAutoCommit(false);

此为设置为自动提交(改为false,也就是改为手动提交)

②、提交事务:conn.commit();

③、回滚事务:conn.rollback();          (都被封装成了方法)

注意:

控制事务的connnection必须是同一个!

执行sql的conn

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值