CALCINIT.sql 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. DROP PROCEDURE IF EXISTS `CALCINIT`;
  2. delimiter ;;
  3. CREATE PROCEDURE `CALCINIT`(IN `PCPID` INT, IN `PCALCMONTH` TINYINT, IN `PCALCYEAR` INT)
  4. BEGIN
  5. DECLARE
  6. AC_USER_NO INT; -- 邀请会员达标数
  7. DECLARE
  8. MLIMITPV, -- 邀请会员不及格达标PV
  9. AC_PERF_PV DECIMAL ( 10, 2 ); -- 邀请会员及格达标PV
  10. -- 查询第一个级别的邀请会员数、达标PV值以及等奖比例
  11. SELECT
  12. T.ACHIEVE_PV,
  13. T.ACHIEVE_PERF_PV,
  14. T.ACHIEVE_MEMBER_NUM
  15. INTO MLIMITPV, AC_PERF_PV, AC_USER_NO
  16. FROM
  17. AR_EMPLOY_LEVEL T
  18. WHERE
  19. T.ID = 'E121497617216708615';
  20. INSERT INTO AR_BS_BONUS_103_CALC (
  21. LAST_DEC_LV,
  22. LAST_EMP_LV,
  23. LAST_STATUS,
  24. USER_ID,
  25. INTRODUCER_ID,
  26. LAYER,
  27. PV,
  28. GPV10,
  29. GPV,
  30. GPV_4_CALC,
  31. USER_TYPE10,
  32. USER_TYPE,
  33. BONUS10,
  34. BONUS20,
  35. BONUS30,
  36. BONUS40,
  37. BONUS50,
  38. BONUS60,
  39. BONUS70,
  40. BONUS80,
  41. BONUS90,
  42. BONUS100,
  43. BONUS110,
  44. BONUS,
  45. PRODUCT_POINT,
  46. CALC_PERIOD_ID,
  47. ACHIEVE_MEMBER_NUM,
  48. ACHIEVE_PERF_PV
  49. ) SELECT
  50. AU.LAST_DEC_LV,
  51. AU.EMP_LV,
  52. AU.STATUS,
  53. AU.ID,
  54. IFNULL( AURN.PARENT_UID, 0 ),
  55. AURN.TOP_DEEP,
  56. IFNULL( AO.PV, 0 ),
  57. 0,
  58. 0,
  59. 0,
  60. 0,
  61. 0,
  62. 0,
  63. 0,
  64. 0,
  65. 0,
  66. 0,
  67. 0,
  68. 0,
  69. 0,
  70. 0,
  71. 0,
  72. 0,
  73. 0,
  74. 0,
  75. PCPID,
  76. IFNULL(DO.ACHIEVE_MEMBER_NUM, 0),
  77. IF(DO.ACHIEVE_MEMBER_NUM >= AC_USER_NO, AC_PERF_PV, MLIMITPV)
  78. FROM
  79. AR_USER AU
  80. INNER JOIN AR_USER_RELATION_NEW AURN ON AU.ID = AURN.USER_ID
  81. LEFT JOIN (
  82. SELECT
  83. USER_ID,
  84. SUM( PV ) PV
  85. FROM
  86. AR_PERF_ORDER
  87. WHERE
  88. PERIOD_NUM IN ( SELECT PERIOD_NUM FROM AR_PERIOD WHERE CALC_YEAR = PCALCYEAR AND CALC_MONTH = PCALCMONTH )
  89. GROUP BY
  90. USER_ID
  91. ) AO ON AO.USER_ID = AU.ID
  92. LEFT JOIN (
  93. SELECT
  94. R.PARENT_UID,
  95. COUNT(R.USER_ID) AS ACHIEVE_MEMBER_NUM
  96. FROM
  97. AR_PERF_ORDER O
  98. INNER JOIN AR_USER_RELATION_NEW R ON O.USER_ID = R.USER_ID
  99. WHERE
  100. O.DEC_TYPE = 'ZC' AND O.PERIOD_NUM IN ( SELECT PERIOD_NUM FROM AR_PERIOD WHERE CALC_YEAR = PCALCYEAR AND CALC_MONTH = PCALCMONTH )
  101. GROUP BY R.PARENT_UID
  102. ) DO ON DO.PARENT_UID = AU.ID
  103. WHERE
  104. AU.DELETED = 0;
  105. END
  106. ;;