java-高并发状态下修改数据库的操作

在高并发状态下,尤其数据在频繁修改的状态下,很可能出现脏数据,也有可能造成脏读,不可重复读等问题,那么怎么解决这种问题呢,其实解决方式有很多中,我们探讨出来的结果是,在频繁修改的表里面添加一个时间戳或者随机数的字段,例如,timestamp。

原理是当每一次修改数据的时候都要把之前的时间戳修改成当前的时间戳,并且之前的时间戳要作为where条件,如果之前的时间戳和参数里面的时间戳不一致,则修改失败,在重新查询进行反复操作,上代码:

try {
if (count>5) {
return “”;
}
Serialize serialize = serializeManager.queryByType(serviceType);
if (serialize!=null) {
Serialize serializeUpdate = new Serialize();
serializeUpdate.setId(serialize.getId());
serializeUpdate.setRandomCode(serialize.getRandomCode());
serializeUpdate.setRandomCodeNew(UUID.randomUUID().toString());
serializeUpdate.setSerializeStart(serialize.getSerializeStart()+1);
boolean flag = serializeManager.updateByRandom(serializeUpdate);
if (flag) {
return serialize.getSerializeCode()+(serialize.getSerializeStart()+1);
}else {
count++;
return getCode(serviceType,count);
}
}else {
return “”;
}
} catch (Exception e) {
e.printStackTrace();
return “”;
}
流程:1.首先查询出来当前信息,

        2.根据之前的随机码并作为修改时候的条件

        3.修改新生成的随机码,如果修改失败,则递归调用一次本方法。直到成功。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

活力好心情

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值