说说 问题,数据库 被插入了两条数据 排查 记录,看到如下 代码:
断点设置为 多线程
发送了两个请求 看到 两个线程都 停在这
分析 插入两条的原因:由于 加了synchronized 所以 有个 先后 顺序 但是 数据库 mysql5.7 默认隔离级别 为 可重复 读,所以第一个 线程 保存一条数据,另一个线程 去查 的时候 还是 查不到的,所以 就保存了 两次。
解决方案 很多 :直接 唯一索引 或者 用 lock 尝试 获取锁,获取不到 就不执行。
这里 抛一个问题,加入 service 出异常 重试 能查到 最新插入数据库里面的数据吗,答案 是可以的。因为 spring 事务 逻辑 理论 上 就是
设置 连接 false 然后手动 提交,重试的时候 事务 已经 重新 开始了,所以拿的到最新的数据库数据。
网友评论