Spring——事物操作

本文详细介绍了Spring中的事务操作,从事务的基本概念出发,包括原子性、一致性、隔离性和持久性等四大特性。接着讨论了在实际操作环境中如何搭建事务处理,并通过Spring进行事务管理,涉及编程式和声明式事务管理,特别是注解声明式事务管理的配置和参数说明。最后,提到了XML声明式事务管理和完全注解声明式事务管理的应用。
摘要由CSDN通过智能技术生成

一、事物操作(事物概念)

1、事物

事物是数据库操作最基本单元,逻辑上一组操作,要么成功,如果有一个失败所有操作都失败

2、场景举例

例如:银行转账

(1)Luck转账给100元给mary

(2)lucy—100元,mary+100元

3、事物四个特性(ACID)

(1)原子性(Atomicity)

        原子性是指事务包含的所有操作要么全部成功,要么全部失败回滚,因此事务的操作如果成功就必须要完全应用到数据库,如果操作失败则不能对数据库有任何影响。

(2)一致性(Consistency)

        一致性是指事务必须使数据库从一个一致性状态变换到另一个一致性状态,也就是说一个事务执行之前和执行之后都必须处于一致性状态。举例来说,假设用户A和用户B两者的钱加起来一共是1000,那么不管A和B之间如何转账、转几次账,事务结束后两个用户的钱相加起来应该还得是1000,这就是事务的一致性。

(3)隔离性(Isolation)

        隔离性是当多个用户并发访问数据库时,比如同时操作同一张表时,数据库为每一个用户开启的事务,不能被其他事务的操作所干扰,多个并发事务之间要相互隔离。关于事务的隔离性数据库提供了多种隔离级别,稍后会介绍到。

(4)持久性(Durability)

        持久性是指一个事务一旦被提交了,那么对数据库中的数据的改变就是永久性的,即便是在数据库系统遇到故障的情况下也不会丢失提交事务的操作。例如我们在使用JDBC操作数据库时,在提交事务方法后,提示用户事务操作完成,当我们程序执行完成直到看到提示后,就可以认定事务已经正确提交,即使这时候数据库出现了问题,也必须要将我们的事务完全执行完成。否则的话就会造成我们虽然看到提示事务处理完毕,但是数据库因为故障而没有执行事务的重大错误。这是不允许的。

二、事物操作(搭建实务操作环境)

 1、创建数据库表,添加记录

2、创建service,搭建dao,完成对象创建和注入关系

(1)service注入dao,在dao注入JdbcTemplate,在JdbcTemplate注入DataSource

@Service
public class UserService {

    //注入dao
    @Autowired
    private UserDao userDao;
}
@Repository
public class UserDaoImpl {

    @Autowired
    private JdbcTemplate jdbcTemplate;
}

3、在dao创建两个方法:多钱和少钱的方法,在service创建方法(转账的方法)

    //luck转账给mary   UserDaoImpl类中
    //多钱
    @Override
    public void addMoney() {
        String sql = "update t_account set money=
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值