前提:
apply_time为datetime类型,jdbcType="TIMESTAMP"
如果Java中时间参数是String类型.
mybatis中可以写成
<if test="param.applyTimeStart!=null and param.applyTimeStart!='' ">AND apply_time >=str_to_date(#{param.applyTimeStart},'%Y-%m-%d %H:%i:%S')</if>
如果Java中时间参数是Date类型.可以写成
<if test="param.applyTimeStart!=null ">AND apply_time >=date_format(#{param.applyTimeStart},'%Y-%m-%d %H:%i:%S')</if>
注意:
只有String类型时才能用<if test="param.applyTimeStart!=null and param.applyTimeStart!='' ">
<if test="param.applyTimeStart!=null and param.applyTimeStart!='' ">
当参数是Date类型时,还有and param.applyTimeStart!=''会报错invalid comparison: java.util.Date and java.lang.String
### Error querying database. Cause: java.lang.IllegalArgumentException: invalid comparison: java.util.Date and java.lang.String
### Cause: java.lang.IllegalArgumentException: invalid comparison: java.util.Date and java.lang.String
java.util.Date 和 java.lang.String不能进行比较.
拓展:
DATE_FORMAT(date,format)函数用于格式化时间,参数是日期和格式字符串.
STR_TO_DATE(str,format)是DATE_FORMAT()的反函数,用于将字符串格式化为时间.STR_TO_DATE的字符串格式必须与format格式一致.-与/要一致.比如:
SELECT STR_TO_DATE('07-23-2020', '%m-%d-%Y'); -- 显示2020-07-23
SELECT STR_TO_DATE('2020-07-23-2020', '%Y-%m-%d'); -- 显示2020-07-23
SELECT STR_TO_DATE('2020-07-23', '%Y-%m-%d'); -- 显示2020-07-23
SELECT STR_TO_DATE('07/23/2020', '%m-%d-%Y'); -- 显示空
format的写法一般用4位年份,24小时制.即只需大写Y和大写H
str_to_date(#{param.applyTimeStart},'%Y-%m-%d %H:%i:%s')