MyBatis中如何计算数值

MyBatis中如何计算加减乘除:

先来看一下mysql中的写法:

update table set
 bean = (case when FLOOR(((bean / 400) * 675)) > 5000 then 5000 else FLOOR(((bean / 400) * 675)) end)
        where DATE_TIME = '2021-02-05'

这里的FLOOR是舍小数位,向下取整。

再来看一下MyBatis的写法:

<update id="updateDetailAwardBean" parameterType="java.util.Map">
        update table set
            bean = (case when FLOOR(((bean / ${param.guessBeanCount}) * ${param.sumPrizePool})) > 5000 then 5000 else FLOOR(((bean / ${param.guessBeanCount}) * ${param.sumPrizePool})) end)
        where DATE_TIME = #{param.currentDate,jdbcType=VARCHAR}
    </update>

这里需要注意的是传入参数的#和$的用法。
尝试过用#传入参数指定jdbcType=INTEGER,不好使,只能写$

或者用<![CDATA[]]>将代码写入中括号里面。这样就会被认为是纯文本。

以上就是MyBatis中计算数值的方式,感谢各位观看,如果有不对的地方还请各位大佬指教。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值