IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> mybatis-plus框架一对多查询分页total和size错误 -> 正文阅读

[移动开发]mybatis-plus框架一对多查询分页total和size错误

先写出错误的代码

Mapper层接口

List<OrderVO> selectOrderPage(IPage page, OrderVO order);

mapperXml

 <resultMap id="orderResultMap" type="com.ht.store.entity.Order">
    <id column="orderId" property="id"/>
    <result column="amount" property="amount"/>
    <result column="transport" property="transport"/>
    <result column="address_id" property="addressId"/>
    <result column="pay_way" property="payWay"/>
    <result column="remark" property="remark"/>
    <result column="goods_name" property="goodsName"/>
    <result column="openid" property="openid"/>
    <result column="create_user" property="createUser"/>
    <result column="create_time" property="createTime"/>
    <result column="update_user" property="updateUser"/>
    <result column="update_time" property="updateTime"/>
    <result column="create_dept" property="createDept"/>
    <result column="is_deleted" property="isDeleted"/>
    <result column="status" property="status"/>
</resultMap>

<resultMap id="orderVoResultMap" type="com.ht.store.vo.OrderVO" extends="orderResultMap">
    <association property="orderRefund" javaType="com.ht.store.entity.OrderRefund">
        <result column="refund_amount" property="refundAmount"/>
    </association>
    <collection property="goodsList" javaType="java.util.ArrayList" ofType="com.ht.store.entity.OrderGoods">
        <result column="goods_id" property="goodsId"/>
        <result column="goods_name" property="goodsName"/>
        <result column="order_id" property="orderId"/>
        <result column="goods_price" property="goodsPrice"/>
        <result column="goods_count" property="goodsCount"/>
        <result column="goods_money" property="goodsMoney"/>
        <result column="goods_category" property="goodsCategory"/>
        <result column="goods_img" property="goodsImg"/>
    </collection>
</resultMap>
<select id="selectOrderPage" resultMap="orderVoResultMap" parameterType="com.ht.store.entity.Order">
SELECT
      o.*,
      og.id as og_id,
      og.goods_id,
      og.order_id,
      og.goods_price,
      og.goods_count,
      og.goods_money,
      og.goods_category,
      og.goods_img,
      r.id as or_id,
      r.refund_amount
  FROM
      orders o
          LEFT JOIN order_goods og ON o.id = og.order_id
          LEFT JOIN order_refund r ON o.id = r.order_id
  WHERE o.is_deleted = 0
  <if test="order.id != null">
     and o.id = #{order.id}
  </if>
  <if test="order.status != null">
      and o.status = #{order.status}
  </if>
  <if test="order.transport != null">
      and o.transport = #{order.transport}
  </if>
  <if test="order.payWay != null">
      and o.pay_way = #{order.payWay}
  </if>
  <if test="order.openid != null">
      and o.openid = #{order.openid}
  </if>
  <if test="order.createTime != null">
      and o.create_time = #{order.createTime}
  </if>
  <if test="order.startTime != null">
      and o.create_time &gt;= #{order.startTime}
  </if>
  <if test="order.endTime != null">
      and o.create_time &lt;= #{order.endTime}
  </if>
  <if test="order.goodsName != null and order.goodsName !=''">
      and og.goods_name like concat('%','${order.goodsName}','%')
  </if>-->
</select>

修改之后的代码:

<resultMap id="orderResultMap" type="com.ht.store.entity.Order">
        <id column="orderId" property="id"/>
        <result column="amount" property="amount"/>
        <result column="transport" property="transport"/>
        <result column="address_id" property="addressId"/>
        <result column="pay_way" property="payWay"/>
        <result column="remark" property="remark"/>
        <result column="goods_name" property="goodsName"/>
        <result column="openid" property="openid"/>
        <result column="create_user" property="createUser"/>
        <result column="create_time" property="createTime"/>
        <result column="update_user" property="updateUser"/>
        <result column="update_time" property="updateTime"/>
        <result column="create_dept" property="createDept"/>
        <result column="is_deleted" property="isDeleted"/>
        <result column="status" property="status"/>
    </resultMap>

    <resultMap id="orderVoResultMap" type="com.ht.store.vo.OrderVO" extends="orderResultMap">
        <association property="orderRefund" javaType="com.ht.store.entity.OrderRefund" column="orderId"
                     select="com.ht.store.mapper.OrderRefundMapper.selectOrderRefundByOrderId">
        </association>
        <collection property="goodsList" javaType="java.util.ArrayList" ofType="com.ht.store.entity.OrderGoods"
        column="orderId" select="com.ht.store.mapper.OrderGoodsMapper.selectGoodsListByOrderId">
        </collection>
    </resultMap>

<select id="selectOrderPage" resultMap="orderVoResultMap" parameterType="com.ht.store.entity.Order">
   SELECT
       o.*,
       o.id as orderId
   FROM
       orders o
   WHERE o.is_deleted = 0
       <if test="order.id != null">
           and o.id = #{order.id}
       </if>
       <if test="order.status != null">
           and o.status = #{order.status}
       </if>
       <if test="order.transport != null">
           and o.transport = #{order.transport}
       </if>
       <if test="order.payWay != null">
           and o.pay_way = #{order.payWay}
       </if>
       <if test="order.openid != null">
           and o.openid = #{order.openid}
       </if>
       <if test="order.createTime != null">
           and o.create_time = #{order.createTime}
       </if>
       <if test="order.startTime != null">
           and o.create_time &gt;= #{order.startTime}
       </if>
       <if test="order.endTime != null">
           and o.create_time &lt;= #{order.endTime}
       </if>
</select>

com.ht.store.mapper.OrderRefundMapper.selectOrderRefundByOrderId接口

mapper

OrderRefund selectOrderRefundByOrderId(String orderId);

mapperXml

<select id="selectOrderRefundByOrderId" resultMap="orderRefundResultMap">
    select * from order_refund where is_deleted = 0 and order_id = #{orderId}
</select>

com.ht.store.mapper.OrderGoodsMapper.selectGoodsListByOrderId接口

List<OrderGoods> selectGoodsListByOrderId(String orderId);

mapperXml

<select id="selectCartGoodsPage" resultMap="cartGoodsResultMap">
    select * from cart_goods where is_deleted = 0
</select>

修改之后total和size均已正常

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2022-04-24 09:34:21  更:2022-04-24 09:35:52 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 23:50:20-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码