日常总结 postgresql批量删除 mybatis动态sql spring事物

今天在写业务代码时,需要写一个删除数据库记录的方法。然而要操作的表被其他的表依赖。也就是本表的主键是其他表的外键。但是数据库并没有设计外键,所以只能手动删除关联表的信息  。用的框架是spring,dubbo,mybatis,数据库是postgresql。因为设计到多条sql语句。当然要用事务来解决数据的一致性和完整性的问题。下面先来重新学习一下spring事务。  数据库事务有严格的定义,必...
摘要由CSDN通过智能技术生成

今天在写业务代码时,需要写一个删除数据库记录的方法。然而要操作的表被其他的表依赖。也就是本表的主键是其他表的外键。但是数据库并没有设计外键,所以只能手动删除关联表的信息  。用的框架是spring,dubbo,mybatis,数据库是postgresql。因为设计到多条sql语句。当然要用事务来解决数据的一致性和完整性的问题。下面先来重新学习一下spring事务。

  数据库事务有严格的定义,必须同时满足:原子性,一致性,隔离性,持久性。

原子性:表示组成一个事务的多条sql语句是一个不可分割的数据单元。所有语句执行成功才能提交,只要有一条语句执行失败,所有操作必须全部撤销。让数据库返回初始状态。

一致性:事务操作成功后,数据次所处的状态和这个数据库业务规则是一致的,数据不会被破坏。假如在银行系统中,两个人相互转账,他们的总存款数应该不变,不能因为事务的执行发生变化。

隔离性:在并发操作时,各个事务拥有各自的操作空间,他们的操作不会对对方产生干扰。数据库规定了不同的隔离级别,不同级别对应在并发操作数据库时的不同干扰程度。隔离级别越高,数据一致性越好,但是并发性越弱。

持久性:一旦事务执行成功。就会被持久化到数据库。

其中“一致性”是最终目标。其他三个特性都是为了达到这一目标所确定的。

数据并发问题:

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值