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中的大于小于号(>,<),要转义,变成>
和<
<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') >= #{startTime,jdbcType=VARCHAR}
</if>
<if test="endTime != null">
and DATE_FORMAT(order_time,'%Y-%m-%d') <= #{endTime,jdbcType=VARCHAR}
</if>
</select>