80 lines
4.7 KiB
XML
80 lines
4.7 KiB
XML
<?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.hzs.member.achieve.mapper.CuMemberMonthAchieveMapper">
|
|
|
|
<!-- 通用查询映射结果 -->
|
|
<resultMap id="CuMemberMonthAchieve" type="com.hzs.common.domain.member.ext.CuMemberMonthAchieveExt">
|
|
<id column="PK_ID" property="pkId" />
|
|
<result column="DEL_FLAG" property="delFlag" />
|
|
<result column="CREATION_TIME" property="creationTime" />
|
|
<result column="MODIFIED_TIME" property="modifiedTime" />
|
|
<result column="PK_COUNTRY" property="pkCountry" />
|
|
<result column="PK_CREATOR" property="pkCreator" />
|
|
<result column="PK_MODIFIED" property="pkModified" />
|
|
<result column="PK_MEMBER" property="pkMember" />
|
|
<result column="PERIOD" property="period" />
|
|
<result column="SETTLE_MONTH" property="settleMonth" />
|
|
<result column="RECOMMEND_MONEY" property="recommendMoney" />
|
|
<result column="RECOMMEND_ACHIEVE" property="recommendAchieve" />
|
|
<result column="REPURCHASE_MONEY" property="repurchaseMoney" />
|
|
<result column="REPURCHASE_ACHIEVE" property="repurchaseAchieve" />
|
|
<result column="WALL_TYPE" property="wallType" />
|
|
<result column="MONEY" property="money" />
|
|
<result column="MEMBER_NAME" property="memberName" />
|
|
<result column="HEAD_PATH" property="headPath" />
|
|
</resultMap>
|
|
<insert id="insertCuMemberMonthAchieve">
|
|
merge into CU_MEMBER_MONTH_ACHIEVE a
|
|
using(
|
|
select pk_member,#{period} period,RECOMMEND_MONEY,RECOMMEND_ACHIEVE,REPURCHASE_MONEY,REPURCHASE_ACHIEVE,pk_country from(
|
|
select pk_member,pk_country,sum(REGISTER_NEW_AMOUNT+UPGRADE_NEW_AMOUNT) RECOMMEND_MONEY,sum(REGISTER_NEW_PV+UPGRADE_NEW_PV) RECOMMEND_ACHIEVE,
|
|
sum(REPURCHASE_NEW_AMOUNT+HI_FUN_NEW_AMOUNT+MALL_NEW_AMOUNT) REPURCHASE_MONEY,sum(REPURCHASE_PV+HI_FUN_NEW_PV+MALL_NEW_PV) REPURCHASE_ACHIEVE from ${tableName}
|
|
where REGISTER_NEW_AMOUNT+UPGRADE_NEW_AMOUNT>0 or REPURCHASE_NEW_AMOUNT+HI_FUN_NEW_AMOUNT+MALL_NEW_AMOUNT>0
|
|
group by pk_member,pk_country)
|
|
) b
|
|
on (a.pk_member=b.pk_member and a.period=b.period)
|
|
when matched then
|
|
update set a.RECOMMEND_MONEY = b.RECOMMEND_MONEY, a.RECOMMEND_ACHIEVE=b.RECOMMEND_ACHIEVE,
|
|
a.REPURCHASE_MONEY=b.REPURCHASE_MONEY,a.REPURCHASE_ACHIEVE=b.REPURCHASE_ACHIEVE
|
|
WHEN NOT MATCHED THEN
|
|
insert(PK_ID, PK_MEMBER, PERIOD, SETTLE_MONTH, RECOMMEND_MONEY,RECOMMEND_ACHIEVE,REPURCHASE_MONEY,
|
|
REPURCHASE_ACHIEVE,PK_COUNTRY,PK_CREATOR)
|
|
values (CU_MEMBER_MONTH_ACHIEVE_SEQ.NEXTVAL,
|
|
b.pk_member,b.period,#{month},b.RECOMMEND_MONEY,b.RECOMMEND_ACHIEVE,b.REPURCHASE_MONEY,
|
|
b.REPURCHASE_ACHIEVE,b.PK_COUNTRY,1)
|
|
</insert>
|
|
<select id="queryCuMemberMonthAchieveByDate" resultMap="CuMemberMonthAchieve">
|
|
select * from(
|
|
select * from (
|
|
select pk_member,pk_country,${recommend} wall_type,sum(recommend_money) money from CU_MEMBER_MONTH_ACHIEVE
|
|
where del_flag=0 and period >= #{startPeriod} and period < #{endPeriod}
|
|
group by pk_member,pk_country
|
|
order by sum(recommend_money) desc
|
|
) where rownum <= 3
|
|
union
|
|
select * from (
|
|
select pk_member,pk_country,${repurchase} wall_type,sum(repurchase_money) money from CU_MEMBER_MONTH_ACHIEVE
|
|
where del_flag=0 and period >= #{startPeriod} and period < #{endPeriod}
|
|
group by pk_member,pk_country
|
|
order by sum(repurchase_money) desc
|
|
) where rownum <= 3) a
|
|
order by wall_type,a.money desc
|
|
</select>
|
|
<select id="queryCuMemberMonthAchieveRecommend" resultMap="CuMemberMonthAchieve">
|
|
select rownum rank, nvl(cu.nick_name, cu.member_name) member_name, cu.HEAD_PATH,a.money from (
|
|
select pk_member,sum(recommend_money) money from CU_MEMBER_MONTH_ACHIEVE
|
|
where del_flag = 0 and pk_country= #{pkCountry}
|
|
and period between #{startPeriod} and #{endPeriod}
|
|
group by pk_member
|
|
order by sum(recommend_money) desc) a
|
|
inner join cu_member cu
|
|
on a.pk_member=cu.pk_id
|
|
where rownum <= 3
|
|
</select>
|
|
|
|
<select id="queryCuMemberMonthAchieveInfo" resultType="com.hzs.member.achieve.controller.vo.RealPerformanceVo">
|
|
select nvl(sum(A_NEW_PV),0) firstLeftPurchaseTotal,nvl(sum(B_NEW_PV),0) firstRightPurchaseTotal,nvl(sum(REP_A_NEW_PV),0) firstLeftRepurchaseTotal,nvl(sum(REP_B_NEW_PV),0) firstRightRepurchaseTotal
|
|
from ${achieveTable} WHERE pk_member=#{pkMember}
|
|
</select>
|
|
</mapper>
|