使用Mybatis映射时间 DateTime ==> LocalDateTime

首先查看,数据库字段:

书写映射实体类对象VO:

java 复制代码
@Data
public class OrderListVO implements Serializable {
    private Integer orderId;
    private String memberName;
    private String orderNumber;
    private BigDecimal orderPrice;
    private String logisticsNo;
    private String status;
    private LocalDateTime createTime;
    private LocalDateTime sendTime;
}

编写sql语句:

java 复制代码
  <select id="select" resultMap="orderPageList" parameterType="net.wanho.qz112.shop.order.dto.OrderListDTO">
        SELECT sod.order_id orderId, sm.username memberName,
        sod.order_number orderNumber,
        sod.order_price orderPrice,
        sod.is_send isSend,
        sod.logistics_no logisticsNo,
        sod.`status`,
        sod.create_time createTime,
        sod.send_time sendTime
        FROM `sp_order` sod
        LEFT JOIN sp_member sm on sod.member_id = sm.id
        where sm.is_deleted = 0
        <if test="orderNumber!=null and orderNumber!=''">
            and order_number=#{orderNumber}
        </if>
        <if test="username!=null and username!=''">
            and username=#{memberName}
        </if>
        <if test="isSend!=null and isSend!=''">
            and is_send=#{isSend}
        </if>
        <if test="status!=null">
            and status=#{status}
        </if>
        <if test="beginTime!=null and endTime!=null">
            and create_time BETWEEN #{beginTime} AND #{endTime}
        </if>
    </select>

编写映射Map:

java 复制代码
    <resultMap id="orderPageList" type="net.wanho.qz112.shop.order.vo.OrderListVO">
        <id column="orderId" property="orderId"/>
        <result column="memberName" property="memberName"/>
        <result column="orderNumber" property="orderNumber"/>
        <result column="orderPrice" property="orderPrice"/>
        <result column="isSend" property="isSend"/>
        <result column="logisticsNo" property="logisticsNo"/>
        <result column="status" property="status"/>
        <result column="createTime" property="createTime"/>
        <result column="sendTime" property="sendTime"/>
    </resultMap>

mapper接口:

java 复制代码
    List<OrderListVO> select(OrderListDTO orderListDTO);

service:接口

java 复制代码
    Map<String, Object> findOrder(Integer pageNum, Integer pageSize, OrderListDTO order);

映射完成后,通过serviceImpl调用:

java 复制代码
    public Map<String, Object> findOrder(Integer pageNum, Integer pageSize, OrderListDTO order) {
        PageHelper.startPage(pageNum,pageSize);
        List<OrderListVO> list = orderMapper.select(order);
        Map<String,Object> map = new HashMap<>(3);
        PageInfo pageInfo = new PageInfo(list);
        map.put("total",pageInfo.getTotal());
        map.put("pageNum", pageInfo.getPageNum());
        map.put("orders", pageInfo.getList());
        return map;
    }

controller:

java 复制代码
    @Resource
    private OrderService orderService;

   @GetMapping("/orders")
    public AjaxResult findPage(Integer pageNum, Integer pageSize, OrderListDTO order) {
        Map<String,Object> map = orderService.findOrder(pageNum,pageSize,order);
        return AjaxResult.success("获取订单列表成功!",map);
    }

实现图片:

此处有弊端,请移步下一篇......

使用LocalDateTime不能映射空值?

相关推荐
山峰哥18 小时前
Python爬虫实战:从零构建高效数据采集系统
开发语言·数据库·爬虫·python·性能优化·架构
_OP_CHEN19 小时前
【C++数据结构进阶】从B + 树 / B * 树到数据库索引:B树的进化之路与 MySQL 实战解析
数据结构·数据库·b树·mysql·innodb·b+树·mylsam
cike_y1 天前
Mybatis之解析配置优化
java·开发语言·tomcat·mybatis·安全开发
云老大TG:@yunlaoda3601 天前
华为云国际站代理商TaurusDB的成本优化体现在哪些方面?
大数据·网络·数据库·华为云
TG:@yunlaoda360 云老大1 天前
华为云国际站代理商GeminiDB的企业级高可用具体是如何实现的?
服务器·网络·数据库·华为云
QQ14220784491 天前
没有这个数据库账户,难道受到了sql注入式攻击?
数据库·sql
残 风1 天前
pg兼容mysql框架之语法解析层(openHalo开源项目解析)
数据库·mysql·开源
勇往直前plus1 天前
MyBatis/MyBatis-Plus类型转换器深度解析:从基础原理到自定义实践
数据库·oracle·mybatis
cyhysr1 天前
sql将表字段不相关的内容关联到一起
数据库·sql
九皇叔叔1 天前
MySQL 数据库 MVCC 机制
数据库·mysql