mybatis中对mysqlDateTime类型转换为Date

本文探讨了在MySQL中DateTime与Date类型之间的转换方法,特别是在使用MyBatis框架进行数据库查询时,如何处理不同类型参数的匹配问题。文章提供了具体的SQL语句示例,展示了如何通过DATE_FORMAT函数将DateTime字段转换为Date类型,以便于与传入的Date类型参数进行正确比对。

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

如果mysql时间类型为DateTime,通过传入格式为Date类型的参数是无法查询出对应的数据,需要对类型做转换
将mysql的数据类型转换为'%Y-%m-%d'
传入的参数类型jdbcType=DATE

<select id="selectPushData" parameterType="com.credlink.wechat.demo.entity.Wecaht_Push_Monitor_Template_Info" resultType="com.credlink.wechat.demo.entity.Wecaht_Push_Monitor_Template_Info">
    select enterprie_id,
           enterprie_name,
           monitor_title,
           monitor_item,
           monitor_level_id,
           alter_date,
           publish_date,
           info_url
        from wecaht_push_monitor_template_info
    <choose>
        <when test="alter_date != null">
            where DATE_FORMAT(alter_date,'%Y-%m-%d') = #{alter_date, jdbcType=DATE}
        </when>
        <when test="enterprie_name != null and enterprie_name !=''">
            where enterprie_name = #{enterprie_name}
        </when>
        <otherwise>
            where monitor_level_id = #{monitor_level_id}
        </otherwise>
    </choose>
    order by alter_date DESC, enterprie_name, monitor_level_id
</select>

 

mysql时间类型转换

SELECT DATE_FORMAT(NOW(),’%Y-%m-%d’)       #输出类型DATE
输出结果:2020-04-18
SELECT DATE_FORMAT(NOW(),’%Y-%m-%d-%T’)    #输出类型DATETIME
输出结果:2020-04-18-10:39:14
SELECT DATE_FORMAT(NOW(),’%Y’)             #输出类型YEAR
输出结果:2020
SELECT DATE_FORMAT(NOW(),’%y’)             #输出类型YEAR
输出结果:20
SELECT DATE_FORMAT(NOW(),’%m’)             #输出类型 MONTH
输出结果:04
SELECT DATE_FORMAT(NOW(),’%d’)             #输出类型DAY
输出结果:18
SELECT DATE_FORMAT(NOW(),’%T’)             #输出类型TIME
输出结果:10:35:32

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值