MySQL 时间段条件查询

本文介绍在MyBatis中如何根据不同类型的Java时间参数(String与Date)设置SQL时间条件,包括使用DATE_FORMAT()和STR_TO_DATE()函数的方法,并提供具体应用场景示例。

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

使用 DATE_FORMAT() 和STR_TO_DATE()

前提:

apply_time为datetime类型,jdbcType="TIMESTAMP"

如果Java中时间参数是String类型.

mybatis中可以写成

<if test="param.applyTimeStart!=null and param.applyTimeStart!='' ">AND apply_time &gt;=str_to_date(#{param.applyTimeStart},'%Y-%m-%d %H:%i:%S')</if>

如果Java中时间参数是Date类型.可以写成

<if test="param.applyTimeStart!=null ">AND apply_time &gt;=date_format(#{param.applyTimeStart},'%Y-%m-%d %H:%i:%S')</if>

注意:

只有String类型时才能用

<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’)
————————————————
版权声明:本文为优快云博主「飞翔的咩咩」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.youkuaiyun.com/u012483153/article/details/107543052

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值