Springboot使用Request方式接收Date类型的参数问题

Controller

    @PostMapping(value = "/list", name = "订单列表查询")
    @ApiOperation("订单列表查询")
    public ResponseEntity<ResultModel> queryOrderList(@RequestBody CtOrderListQuery query,
                                                      @ApiIgnore @CurrentUser JwtUser jwtuser){
        validate.validateOrderListQuery(query);
        PageInfo<CtOrderVo> pages = ctOrderService.queryOrderList(query);
        return new ResponseEntity<>(ResultModel.ok(pages), HttpStatus.OK);
    }

@RequestBody CtOrderListQuery query 映射前端的json串参数
如:
{
“endTime”: “2021-09-01 12:09:43”,
“startTime”: “2023-12-10 12:09:43”
}

package cn.cntex.textile.cloud.model.command;
@Data
@ToString
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class CtOrderListQuery implements Serializable {

    /**
     * 主键id
     */
    private Long id;

    /**
     * 订单名称
     */
    private String orderName;

    /**
     * 开始时间,这个JosnFormat失效不知道为啥
     * 所以由Date类型换成了String类型
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    private String startTime;

    /**
     * 结束时间,这个JosnFormat失效不知道为啥
     * 所以由Date类型换成了String类型
     */
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    private String endTime;

    /**
     * 分页参数
     */
    private Integer pageNum;

    /**
     * 分页参数
     */
    private Integer pageSize;

}

mybatis的查询语句:
数据库中的 order_time, create_time, update_time都是timestamp类型
1)所以这里先把order_time字段用date_format函数转换了一下DATE_FORMAT(order_time,’%Y-%m-%d’) 在进行日期的比较
2)在xml中的大于小于号(>,<),要转义,变成 &gt;&lt;

 <select id="selectOrderList" parameterType="cn.cntex.textile.cloud.model.command.CtOrderListQuery" resultMap="BaseResultMap">
    select
    <include refid="Base_Column_List" />
    from ct_order
    where 1=1
        <if test="id != null and id !=0">
          and id = #{id,jdbcType=BIGINT}
        </if>
        <if test="orderName != null and orderName != ''">
          and order_name like concat('%',#{orderName,jdbcType=VARCHAR}, '%')
        </if>
        <if test="startTime != null">
          and DATE_FORMAT(order_time,'%Y-%m-%d') &gt;= #{startTime,jdbcType=VARCHAR}
        </if>
        <if test="endTime != null">
          and DATE_FORMAT(order_time,'%Y-%m-%d') &lt;= #{endTime,jdbcType=VARCHAR}
        </if>
  </select>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值