SSM框架中mybatis的*mapper.xml文件异常invalid comparison: java.util.Date and java.lang.String

本文介绍如何在MyBatis中正确使用SQL转义,避免因符号误解析导致的错误。通过具体示例展示了如何转义比较运算符,确保SQL语句能够正确执行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

将之前的

<if test="startInvokeTime != null"  and startInvokeTime != ' ' ''>

and invoke_time >= #{startInvokeTime,jdbcType=TIMESTAMP}
</if>
<if test="endtInvokeTime != null"  and endtInvokeTime != ' '>
<![CDATA[ 
         and invoke_time <= #{endtInvokeTime,jdbcType=TIMESTAMP}
        ]]>
</if>

 

改成

<if test="startInvokeTime != null">

 

and invoke_time >= #{startInvokeTime,jdbcType=TIMESTAMP}
</if>
<if test="endtInvokeTime != null">
<![CDATA[ 
         and invoke_time <= #{endtInvokeTime,jdbcType=TIMESTAMP}
        ]]>

 

</if>

说明:上文中红色标记部分为mybatis中sql的转义,如果不转义,比较的“<”就会被当做xml文件标签的做括号,以至于报错,所以这里需要进行转义

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值