Java中不用事务,如何保证数据一致性?
答案:2 悬赏:60 手机版
解决时间 2021-02-10 20:40
- 提问者网友:蔚蓝的太阳
- 2021-02-10 11:53
Java中不用事务,如何保证数据一致性?
最佳答案
- 五星知识达人网友:等灯
- 2021-02-10 13:15
很难很麻烦,也不是不可以
如果只是对于单表不可重复数据来说,可以设置数据库表的唯一属性来保证
对于多表操作或多数据源操作,只能在业务逻辑中自定义一个写入数据库操作的开关,当业务逻辑都处理完时,在最短时间内将数据同步到数据库。并且在同步完成后,再次查询结果进行数据一致性和正确性验证操作
如果只是对于单表不可重复数据来说,可以设置数据库表的唯一属性来保证
对于多表操作或多数据源操作,只能在业务逻辑中自定义一个写入数据库操作的开关,当业务逻辑都处理完时,在最短时间内将数据同步到数据库。并且在同步完成后,再次查询结果进行数据一致性和正确性验证操作
全部回答
- 1楼网友:野味小生
- 2021-02-10 14:17
以mysql来说,可能出现脏读、不可重复读以及幻读,mysql默认设置是可重复读,即一次事务中不会读取到不同的数据。
可以做如下操作:
1)打开两个客户端,均设置为rr;
2)在一个事务中,查询某个操作查到某份数据;比如是某个字段version=1存在数据;
3)在另一个事务中,删除这份version=1的数据;删除后,在2所属的事务中查询数据是没有变化的,还是存在version=1的数据;
4)当我们在2所属的事务中继续更新数据,那么会发现更新不了,明明我们就看到了这份version=1的数据;
缓存一致性:
缓存一致,与什么一致?是与数据库一致,对外查询每个时刻一致;所以在针对于缓存与数据库之间该先更新哪一个呢?可能有人觉得我先更新数据库,再更新缓存不就行了吗?但是有想过个问题吗?
当用户已经支付成功了,更新到数据库,但是呢?你还在缓存中显示未支付,在用户点击频率很高并且数据库压力过大,来不及同步到缓存时,那你是不是很尴尬,这就是典型的不一致了。此时用户再支付,那你又告诉他已经支付了,那他会把你骂死的
那该怎么来做呢?我们可以这样,先更新缓存再更新数据库,那么存在什么问题呢?
1)缓存更新成功,但是数据库更新失败,而被其它的并发线程访问到
2)缓存淘汰成功,但是数据库更新失败,这也会引发后期数据不一致
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯