SQL语句中insert or update语句使用排坑

最近业务上需要用到一个insert or update语句,如果数据库中已经存在这一类的数据,就将其统计次数+1,否则就插入
后台语句是这样写的
在这里插入图片描述
数据库四个字段分别为:id、数据源id、日搜索次数、日搜索结果条数
一开始的思路是在java代码中组装好uuid以及需要更新或插入的数据源id,将list传到mapper中循环一次性处理;
但在自测的时候,发现每一个数据源的日搜索次数最多只能变成2,搜素再多次上限也是2;
于是到navicat做了一个测试,后来发现问题出在excluded这个地方
因为我在foreach循环中,传递的默认日搜索次数是1,所以在excluded这里,他并不是用我数据库中的搜索次数+1,而是用我在foreach循环中传递的搜索次数+1,所以导致数据库中搜索很多次也一直都是2;

那么问题找到了,就得找解决办法,我尝试了在最后一条set语句中,使用+=,去掉excluded等等,都不行,后来知道,此处的excluded是用于标记发生conflict的那一次,网上查询了许多办法也没有找到合适的最优解。
此处我最终的解决办法是,在insert or update之前将其数据库中的当前次数查询到后端java代码中,并做完+1和判空置1处理后,当做参数传递进来
在这里插入图片描述
我觉得这肯定不是最优解,奈何水平太低,还望各位路过的大佬指教!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值