UserPerf.php 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206
  1. <?php
  2. namespace common\models;
  3. use common\helpers\user\Info;
  4. use Yii;
  5. /**
  6. * This is the model class for table "{{%USER_PERF}}".
  7. *
  8. * @property string $ID ID
  9. * @property string $USER_ID 会员ID
  10. * @property string $PV_PCS_ZC 个人注册单累计
  11. * @property string $PV_PCS_YH 个人优惠单累计
  12. * @property string $PV_PCS_ZG 个人增购单累计
  13. * @property string $PV_PCS_LS 个人零售单累计
  14. * @property string $PV_PCS_FX 个人复销单累计
  15. * @property string $PV_1L 一市场累计业绩
  16. * @property string $PV_2L 二市场累计业绩
  17. * @property string $PV_3L 三市场累计业绩
  18. * @property string $PV_4L 四市场累计业绩
  19. * @property string $PV_5L 五市场累计业绩
  20. * @property int $CREATED_AT 创建时间
  21. * @property string $PV_PSS 推荐团队累计业绩
  22. * @property string $SURPLUS_1L 一市场结余业绩
  23. * @property string $SURPLUS_1L_ZC 一市场首购结余业绩
  24. * @property string $SURPLUS_1L_FX 一市场复消结余业绩
  25. * @property string $SURPLUS_2L 二市场结余业绩
  26. * @property string $SURPLUS_2L_ZC 二市场首购结余业绩
  27. * @property string $SURPLUS_2L_FX 二市场复消结余业绩
  28. * @property string $SURPLUS_3L 三市场结余业绩
  29. * @property string $SURPLUS_3L_ZC 三市场首购结余业绩
  30. * @property string $SURPLUS_3L_FX 三市场复消结余业绩
  31. * @property string $SURPLUS_4L 四市场结余业绩
  32. * @property string $SURPLUS_4L_ZC 四市场首购结余业绩
  33. * @property string $SURPLUS_4L_FX 四市场复消结余业绩
  34. * @property string $SURPLUS_5L 五市场结余业绩
  35. * @property string $SURPLUS_5L_ZC 五市场首购结余业绩
  36. * @property string $SURPLUS_5L_FX 五市场复消结余业绩
  37. * @property string $PV_PSS_TOTAL 推荐团队累计业绩
  38. */
  39. class UserPerf extends \common\components\ActiveRecord
  40. {
  41. /**
  42. * @inheritdoc
  43. */
  44. public static function tableName()
  45. {
  46. return '{{%USER_PERF}}';
  47. }
  48. /**
  49. * @inheritdoc
  50. */
  51. public function rules()
  52. {
  53. return [
  54. [['USER_ID', 'CREATED_AT'], 'required'],
  55. [['PV_PCS_ZC', 'PV_PCS_FX', 'PV_1L', 'PV_2L', 'PV_3L', 'PV_4L', 'PV_5L', 'PV_PSS', 'SURPLUS_1L', 'SURPLUS_1L_ZC', 'SURPLUS_1L_FX', 'SURPLUS_2L', 'SURPLUS_2L_ZC', 'SURPLUS_2L_FX', 'SURPLUS_3L', 'SURPLUS_3L_ZC', 'SURPLUS_3L_FX', 'SURPLUS_4L', 'SURPLUS_4L_ZC', 'SURPLUS_4L_FX', 'SURPLUS_5L', 'SURPLUS_5L_ZC', 'SURPLUS_5L_FX', 'PV_PSS_TOTAL'], 'number'],
  56. [['CREATED_AT'], 'integer'],
  57. [['USER_ID', 'ID'], 'string', 'max' => 32],
  58. [['USER_ID'], 'unique'],
  59. ];
  60. }
  61. /**
  62. * @inheritdoc
  63. */
  64. public function attributeLabels()
  65. {
  66. return [
  67. 'ID' => 'ID',
  68. 'USER_ID' => '会员ID',
  69. 'PV_PCS_ZC' => '个人注册单累计',
  70. 'PV_PCS_FX' => '个人复销单累计',
  71. 'PV_1L' => '一市场累计业绩',
  72. 'PV_2L' => '二市场累计业绩',
  73. 'PV_3L' => '三市场累计业绩',
  74. 'PV_4L' => '四市场累计业绩',
  75. 'PV_5L' => '五市场累计业绩',
  76. 'CREATED_AT' => '创建时间',
  77. 'PV_PSS' => '推荐团队累计业绩',
  78. 'SURPLUS_1L' => '一市场结余业绩',
  79. 'SURPLUS_1L_ZC' => '一市场首购结余业绩',
  80. 'SURPLUS_1L_FX' => '一市场复消结余业绩',
  81. 'SURPLUS_2L' => '二市场结余业绩',
  82. 'SURPLUS_2L_ZC' => '二市场首购结余业绩',
  83. 'SURPLUS_2L_FX' => '二市场复消结余业绩',
  84. 'SURPLUS_3L' => '三市场结余业绩',
  85. 'SURPLUS_3L_ZC' => '三市场首购结余业绩',
  86. 'SURPLUS_3L_FX' => '三市场复消结余业绩',
  87. 'SURPLUS_4L' => '四市场结余业绩',
  88. 'SURPLUS_4L_ZC' => '四市场首购结余业绩',
  89. 'SURPLUS_4L_FX' => '四市场复消结余业绩',
  90. 'SURPLUS_5L' => '五市场结余业绩',
  91. 'SURPLUS_5L_ZC' => '五市场首购结余业绩',
  92. 'SURPLUS_5L_FX' => '五市场复消结余业绩',
  93. 'PV_PSS_TOTAL' => '推荐团队累计业绩',
  94. ];
  95. }
  96. /**
  97. * 用户累计业绩(默认主库)
  98. * @param $userId
  99. * @param string $db
  100. * @param bool $isSlaves
  101. * @return array|null|\yii\db\ActiveRecord
  102. */
  103. public static function getOneUserPerf($userId, $db = 'db', $isSlaves = false){
  104. $data = static::find($isSlaves, $db)
  105. ->select('USER_ID,PV_PCS_ZC,PV_PCS_FX,PV_PSS,PV_1L,PV_2L,PV_3L,PV_4L,PV_5L,SURPLUS_1L,SURPLUS_2L,SURPLUS_3L,SURPLUS_4L,SURPLUS_5L,SURPLUS_1L_ZC,SURPLUS_2L_ZC,SURPLUS_3L_ZC,SURPLUS_4L_ZC,SURPLUS_5L_ZC,SURPLUS_1L_FX,SURPLUS_2L_FX,SURPLUS_3L_FX,SURPLUS_4L_FX,SURPLUS_5L_FX,PV_PSS_TOTAL')
  106. ->where('USER_ID=:USER_ID', [':USER_ID'=>$userId])
  107. ->asArray()
  108. ->one();
  109. if(!$data){
  110. $data = [
  111. 'USER_ID' => $userId,
  112. 'PV_PCS_ZC' => 0,
  113. 'PV_PCS_FX' => 0,
  114. 'PV_PSS' => 0,
  115. 'PV_1L' => 0,
  116. 'PV_2L' => 0,
  117. 'PV_3L' => 0,
  118. 'PV_4L' => 0,
  119. 'PV_5L' => 0,
  120. 'SURPLUS_1L' => 0,
  121. 'SURPLUS_2L' => 0,
  122. 'SURPLUS_3L' => 0,
  123. 'SURPLUS_4L' => 0,
  124. 'SURPLUS_5L' => 0,
  125. 'SURPLUS_1L_ZC' => 0,
  126. 'SURPLUS_2L_ZC' => 0,
  127. 'SURPLUS_3L_ZC' => 0,
  128. 'SURPLUS_4L_ZC' => 0,
  129. 'SURPLUS_5L_ZC' => 0,
  130. 'SURPLUS_1L_FX' => 0,
  131. 'SURPLUS_2L_FX' => 0,
  132. 'SURPLUS_3L_FX' => 0,
  133. 'SURPLUS_4L_FX' => 0,
  134. 'SURPLUS_5L_FX' => 0,
  135. 'PV_PSS_TOTAL' => 0,
  136. ];
  137. }
  138. return $data;
  139. }
  140. /**
  141. * 操作日志记录条件
  142. * @return array
  143. */
  144. public function attrLabelsWithLogType(){
  145. return [
  146. 'USER_ID' => '会员ID',
  147. 'PV_1L' => '一市场累计业绩',
  148. 'PV_2L' => '二市场累计业绩',
  149. 'PV_3L' => '三市场累计业绩',
  150. 'PV_4L' => '四市场累计业绩',
  151. 'PV_5L' => '五市场累计业绩',
  152. 'PV_PSS' => '推荐团队累计业绩',
  153. ];
  154. }
  155. /**
  156. * 获取一名会员余额
  157. * @param $userId
  158. * @return array|null
  159. */
  160. public static function getPvByUserId($userId){
  161. $data = self::findOneAsArray('USER_ID=:USER_ID', [':USER_ID'=>$userId], 'USER_ID,PV_1L,PV_2L,PV_3L,PV_4L,PV_5L,PV_PSS');
  162. if(!$data){
  163. $data = [
  164. 'USER_ID' => $userId,
  165. 'PV_1L' => 0,
  166. 'PV_2L' => 0,
  167. 'PV_3L' => 0,
  168. 'PV_4L' => 0,
  169. 'PV_5L' => 0,
  170. 'PV_PSS' => 0,
  171. ];
  172. }
  173. return $data;
  174. }
  175. /**
  176. * 获取当前结余业绩
  177. * @param $userId
  178. * @return array|\yii\db\ActiveRecord|null
  179. * @throws \yii\db\Exception
  180. */
  181. public static function getPeriodSurplusPerf($userId){
  182. $result = static::findUseDbCalc()->select('SURPLUS_1L,SURPLUS_2L,SURPLUS_3L,SURPLUS_4L,SURPLUS_5L')->where('USER_ID=:USER_ID', [':USER_ID'=>$userId])->asArray()->one();
  183. if(!$result){
  184. $result = [
  185. 'USER_ID' => $userId,
  186. 'SURPLUS_1L' => 0,
  187. 'SURPLUS_2L' => 0,
  188. 'SURPLUS_3L' => 0,
  189. 'SURPLUS_4L' => 0,
  190. 'SURPLUS_5L' => 0,
  191. 'SURPLUS_LS' => 0,
  192. ];
  193. }
  194. return $result;
  195. }
  196. }