xiaoyong931011
2021-11-18 bdf266ec3535df672c2ca86c638ee60eb7e6ea93
gc-shop/src/main/resources/mapper/shop/JhyOrderMapper.xml
@@ -12,33 +12,57 @@
        a.reserve_time reserveTime,
        a.status status,
        a.remark remark,
        b.nick_name name,
        a.unit_name unitName,
        a.house_number houseNumber,
        a.username name,
        b.mobile_phone mobilePhone,
               (select ifnull(sum(price*weight*40),0) from xzx_jhy_order_items where order_id = a.id) totalPrice,
        d.mobile jhyMobilePhone,
               (select ifnull(sum(score),0) from xzx_jhy_order_items where order_id = a.id) totalPrice,
                (select ifnull(sum(weight),0) from xzx_jhy_order_items where order_id = a.id) totalWeight,
        d.username username
        FROM
        xzx_jhy_order a
        left join xzx_user_info b on b.user_id = a.user_id
        left join xzx_jhy_info d on d.id = a.jhy_id
        left join xzx_jhy_info d on d.user_id = a.jhy_id
        WHERE 1 = 1
        <if test="record.orderNo != null and record.orderNo != ''">
            and a.order_no like concat('%',#{record.orderNo},'%')
        </if>
        <if test="record.status != null and record.status != ''">
            and a.status = #{record.status}
        <if test="record.status.size > 0">
            and a.status in
            <foreach collection="record.status" item="sta" open="(" separator="," close=")">
                #{sta}
            </foreach>
        </if>
        <if test="record.jwyName != null and record.jwyName != ''">
            and (d.username like concat('%',#{record.jwyName},'%')
                 or d.mobile like concat('%',#{record.jwyName},'%'))
        </if>
        <if test="record.account != null and record.account != ''">
            and ( b.nick_name like concat('%',#{record.account},'%')
                      or b.mobile_phone like concat('%',#{record.account},'%') )
            and ( a.username like concat('%',#{record.account},'%')
                      or b.mobile_phone like concat('%',#{record.accountPhone},'%') )
        </if>
        <if test="record.reserveTimeStart != null">
            and a.reserve_time >= #{record.reserveTimeStart}
            and a.reserve_date >= #{record.reserveTimeStart}
        </if>
        <if test="record.reserveTimeEnd != null">
            and a.reserve_time &lt;= #{record.reserveTimeEnd}
            and a.reserve_date &lt;= #{record.reserveTimeEnd}
        </if>
        order by a.CREATED_TIME desc
        order by
        <if test="record.namePx != null and record.namePx != '' and record.namePx == 1">
            a.CREATED_TIME
        </if>
        <if test="record.namePx != null and record.namePx != '' and record.namePx == 2">
            a.username
        </if>
        <if test="record.typePx != null and record.typePx != '' and record.typePx == 1">
            asc
        </if>
        <if test="record.typePx != null and record.typePx != '' and record.typePx == 2">
            desc
        </if>
    </select>
@@ -64,10 +88,42 @@
        FROM
        xzx_jhy_order a
        left join xzx_user_info b on b.user_id = a.user_id
        left join xzx_jhy_info d on d.id = a.jhy_id
        left join xzx_jhy_info d on d.user_id = a.jhy_id
        WHERE a.id=#{id}
    </select>
    <select id="selectJhyOrderTitleStatistics" resultType="java.util.Map">
        select d.title title, sum(b.weight) weight
        from xzx_jhy_order a
           inner join xzx_jhy_order_items b on a.id=b.order_id
           inner join xzx_sys_environmental_info c on b.item_type=c.id
           inner join xzx_sys_environmental_info d on c.parent_id = d.id
        where a.status in (3, 4)
        <if test="userId != null and userId != ''">
            and a.user_id=#{userId}
        </if>
        group by d.title
    </select>
    <select id="selectJhyOrderCnt" resultType="java.lang.Integer">
        select IFNULL(count(1),0) from xzx_jhy_order
        where status in (3, 4)
        <if test="userId != null and userId != ''">
            and user_id=#{userId}
        </if>
    </select>
    <select id="selectTotalScoreHasGet" resultType="java.math.BigDecimal">
        select IFNULL(SUM(b.score), 0) from xzx_jhy_order a
        inner join xzx_jhy_order_items b on a.id=b.order_id
        where a.user_id=#{userId}
    </select>
    <select id="selectJhyInfoByUserId" resultType="com.xzx.gc.entity.JhyInfo">
        select * from xzx_jhy_info where id = #{jhyId}
    </select>
    <select id="selectAddRessInfoByUserId" resultType="com.xzx.gc.entity.AddressInfo">
        select * from xzx_user_address_info where user_id = #{userId}
    </select>
</mapper>