mybatis oracle进行时间计算时报错:ORA-00907: 缺失右括号

在监控数据库某个表中是否存在过期数据时,用到了sysdate- interval xx minute的写法。在mybatis中这样写:

    <select id="countXXXX" parameterType="xxxx.MonitorParamInfo" resultMap="BaseResultMap">
        select
        <include refid="Base_Column_List" />
        from LOG_T
        where TO_CHAR(sysdate- interval #{expireTime} MINUTE, 'YYYYMMDDHH24MISS') <![CDATA[ > ]]> CREATE_TIME
    </select>

这里的expireTime是String类型。代码看似没有问题,但执行会报错:ORA-00907: 缺失右括号。
但直接丢到sql执行时,把expireTime写成固定时间,如下:

        select
        <include refid="Base_Column_List" />
        from LOG_T
        where TO_CHAR(sysdate- interval '5' MINUTE, 'YYYYMMDDHH24MISS') > CREATE_TIME

则可以运行。
如果把 ‘5’ 的单引号直接去掉变成 5 ,在执行器里同样会报缺失右括号的错误,猜想是mybatis在这一块预编译有点问题,传入的字符串不会被加上单引号。翻了网上很多资料,查到一种写法:

    <select id="countXXXX" parameterType="xxxx.MonitorParamInfo" resultMap="BaseResultMap">
        select
        <include refid="Base_Column_List" />
        from LOG_T
        where TO_CHAR(sysdate- numtodsinterval(#{expireTime},'hour'), 'YYYYMMDDHH24MISS') <![CDATA[ > ]]> CREATE_TIME
    </select>

可以解决问题。
有其他写法欢迎补充~~( ˘▽˘)っ

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

星奈ミトラ

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

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

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

打赏作者

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

抵扣说明:

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

余额充值