tk.mybatis中使用PageHelper分页,嵌套导致数据不对

tk.mybatis中使用PageHelper分页,嵌套导致数据不对,实际记录数已嵌套的子记录为准

解决方法:在xml里面修改sql写法

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.imooc.mapper.OrderMapperCustom">
    <resultMap id="myOrderVo" type="com.imooc.pojo.vo.MyOrdersVo">
        <id column="orderId" property="orderId"/>
        <result column="createdTime" property="createdTime"/>
        <result column="payMethod" property="payMethod"/>
        <result column="realPayAmount" property="realPayAmount"/>
        <result column="postAmount" property="postAmount"/>
        <result column="orderStatus" property="orderStatus"/>
        <collection property="subOrderItemList"
                    select="getSubItems"
                    column="orderId"
                    ofType="com.imooc.pojo.vo.MySubOrderItemVO">
            <result column="itemId" property="itemId"/>
            <result column="itemName" property="itemName"/>
            <result column="itemImg" property="itemImg"/>
            <result column="itemSpecName" property="itemSpecName"/>
            <result column="buyCounts" property="buyCounts"/>
            <result column="price" property="price"/>
        </collection>
    </resultMap>
    <!--<select id="queryMyOrders" parameterType="map" resultMap="myOrderVo">
        select
        od.id as orderId,
        od.created_time as createdTime,
        od.pay_method as payMethod,
        od.real_pay_amount as realPayAmount,
        od.post_amount as postAmount,
        os.order_status as orderStatus,
        oi.item_id as itemId,
        oi.item_name as itemName,
        oi.item_img as itemImg,
        oi.item_spec_name as itemSpecName,
        oi.buy_counts as buyCounts,
        oi.price as price
         from orders od
        left join order_status os on od.id=os.order_id
        left join order_items oi on od.id = oi.order_id
        where od.user_id=#{paramsMap.userId}
        <if test="paramsMap.orderStatus != null">
            and os.order_status=#{paramsMap.orderStatus}
        </if>
        and od.is_delete = 0
        order by od.updated_time asc
      </select>-->
    <select id="queryMyOrders" parameterType="map" resultMap="myOrderVo">
        select
        od.id as orderId,
        od.created_time as createdTime,
        od.pay_method as payMethod,
        od.real_pay_amount as realPayAmount,
        od.post_amount as postAmount,
        os.order_status as orderStatus
        from orders od
        left join order_status os on od.id=os.order_id
        where od.user_id=#{paramsMap.userId}
        <if test="paramsMap.orderStatus != null">
            and os.order_status=#{paramsMap.orderStatus}
        </if>
        and od.is_delete = 0
        order by od.updated_time asc
    </select>
    <select id="getSubItems" parameterType="string" resultType="com.imooc.pojo.vo.MySubOrderItemVO">
        select
        oi.item_id as itemId,
        oi.item_name as itemName,
        oi.item_img as itemImg,
        oi.item_spec_name as itemSpecName,
        oi.buy_counts as buyCounts,
        oi.price as price
        from order_items oi
        where oi.order_id=#{orderId}
    </select>

</mapper>

整体思路:先查询订单数据,再根据订单id,查询每个订单的订单商品数据

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值