在监控数据库某个表中是否存在过期数据时,用到了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>
可以解决问题。
有其他写法欢迎补充~~( ˘▽˘)っ