需求:1. 传入开始时间(startTime)和结束时间(endTime), 查询 effective_time 在区间 [startTime, endTime] 中的数据。
Controller 中的时间入参用 String 表示:
// 查询接口,默认查询今年内的数据。
@GetMapping(value = "/getData")
public List<Demo> selectDemoData(@RequestParam(value = "startTime", required = false) String startTime,
@RequestParam(value = "endTime", required = false) String endTime) {
// 校验传入的日期格式
// ...
return demoService.selectDemoData(startTime, endTime);
}
mapper 中的sql操作如下,注意要使用mysql的 str_to_date 函数将字符串转成Date再比较。
<!-- 查询接口,默认查询今年内的数据 -->
<select id="selectDemoData" resultType="Demo">
select *
from `demo`
<where>
<!-- 开始时间和结束时间都为空,则查询今年数据 -->
<if test="(startTime == null or startTime == '') and (endTime == null or endTime == '')">
YEAR(`effective_time`) = YEAR( NOW( ) )
</if>
<!-- 开始时间不为空 -->
<if test="startTime != null and startTime != ''">
and date_format(`effective_time`,'%Y-%m-%d') >= str_to_date(#{startTime},'%Y-%m-%d')
</if>
<!-- 结束时间不为空 -->
<if test="endTime != null and endTime != ''">
and date_format(`effective_time`,'%Y-%m-%d') <= str_to_date(#{endTime},'%Y-%m-%d')
</if>
</where>
</select>
标签:-%,effective,time,查询,date,startTime,mysql,Mybatis,endTime
From: https://www.cnblogs.com/FengZeng666/p/17319624.html