date.php 49 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996
  1. <?php
  2. /**
  3. * 任务计划 - 天执行的任务
  4. *
  5. *
  6. *
  7. *
  8. */
  9. defined('InShopNC') or exit('Access Invalid!');
  10. require_once(BASE_ROOT_PATH . '/helper/notify_helper.php');
  11. require_once(BASE_ROOT_PATH . '/helper/stat_helper.php');
  12. class dateControl extends BaseCronControl
  13. {
  14. /**
  15. * 该文件中所有任务执行频率,默认1天,单位:秒
  16. * @var int
  17. */
  18. const EXE_TIMES = 86400;
  19. /**
  20. * 优惠券即将到期提醒时间,单位:天
  21. * @var int
  22. */
  23. const VOUCHER_INTERVAL = 5;
  24. /**
  25. * 兑换码即将到期提醒时间,单位:天
  26. * @var int
  27. */
  28. const VR_CODE_INTERVAL = 5;
  29. /**
  30. * 订单结束后可评论时间,15天,60*60*24*15
  31. * @var int
  32. */
  33. const ORDER_EVALUATE_TIME = 1296000;
  34. /**
  35. * 每次到货通知消息数量
  36. * @var int
  37. */
  38. const ARRIVAL_NOTICE_NUM = 100;
  39. /**
  40. * 默认方法
  41. */
  42. public function indexOp()
  43. {
  44. //更新订单商品佣金值
  45. $this->_order_commis_rate_update();
  46. //订单超期后不允许评价
  47. $this->_order_eval_expire_update();
  48. //未付款订单超期自动关闭
  49. $this->_order_timeout_cancel();
  50. //增加会员积分和经验值
  51. $this->_add_points();
  52. //自提点中,已经关闭的订单删除
  53. $this->_order_delivery_cancel_del();
  54. //更新订单扩展表收货人所在省份ID
  55. $this->_order_reciver_provinceid_update();
  56. //更新退款申请超时处理
  57. Model('trade')->editRefundConfirm();
  58. //代金券即将过期提醒
  59. $this->_voucher_will_expire();
  60. //虚拟兑换码即将过期提醒
  61. $this->_vr_code_will_expire();
  62. //更新商品访问量
  63. $this->_goods_click_update();
  64. //更新商品促销到期状态
  65. $this->_goods_promotion_state_update();
  66. //更新浏览量
  67. $this->_goods_browse_update();
  68. //缓存订单及订单商品相关数据
  69. $this->_order_goods_cache();
  70. //会员相关数据统计
  71. $this->_member_stat();
  72. $this->_stat_daily();
  73. }
  74. public function nine_clockOp()
  75. {
  76. //订单自动完成
  77. $this->_order_auto_complete();
  78. }
  79. public function ten_clockOp()
  80. {
  81. //已领取但未使用的红包过期通知
  82. $this->bonus_expire_notify();
  83. //商品到货通知提醒
  84. $this->_arrival_notice();
  85. }
  86. public function testOp()
  87. {
  88. $this->_stat_daily();
  89. }
  90. public function _stat_daily()
  91. {
  92. $cur_date = new DateTime();
  93. $inter = new DateInterval('P1D');
  94. $cur_date->sub($inter);
  95. stat_helper::onDaiyMember($cur_date->getTimestamp());
  96. stat_helper::onDaiyBonus($cur_date->getTimestamp());
  97. stat_helper::onDaiyOrder($cur_date->getTimestamp());
  98. }
  99. /**
  100. * 未付款订单超期自动关闭
  101. */
  102. private function _order_timeout_cancel()
  103. {
  104. //实物订单超期未支付系统自动关闭
  105. $_break = false;
  106. $model_order = Model('order');
  107. $logic_order = Logic('order');
  108. $condition = array();
  109. $condition['order_state'] = ORDER_STATE_NEW;
  110. $condition['add_time'] = array('lt',time() - ORDER_AUTO_CANCEL_DAY * self::EXE_TIMES);
  111. //分批,每批处理100个订单,最多处理5W个订单
  112. for ($i = 0; $i < 500; $i++){
  113. if ($_break) {
  114. break;
  115. }
  116. $order_list = $model_order->getOrderList($condition, '', '*', '', 100);
  117. if (empty($order_list)) break;
  118. foreach ($order_list as $order_info)
  119. {
  120. $result = $logic_order->changeOrderStateCancel($order_info,'system','系统','超期未支付系统自动关闭订单',true,false);
  121. if (!$result['state']) {
  122. $this->log('实物订单超期未支付关闭失败SN:'.$order_info['order_sn']); $_break = true; break;
  123. } else {
  124. account_helper::onPredeposit('order_cancel',$order_info['buyer_id'],$order_info['order_sn']);
  125. }
  126. }
  127. }
  128. //虚拟订单超期未支付系统自动关闭
  129. $_break = false;
  130. $model_vr_order = Model('vr_order');
  131. $logic_vr_order = Logic('vr_order');
  132. $condition = array();
  133. $condition['order_state'] = ORDER_STATE_NEW;
  134. $condition['add_time'] = array('lt',time() - ORDER_AUTO_CANCEL_DAY * self::EXE_TIMES);
  135. //分批,每批处理100个订单,最多处理5W个订单
  136. for ($i = 0; $i < 500; $i++){
  137. if ($_break) {
  138. break;
  139. }
  140. $order_list = $model_vr_order->getOrderList($condition, '', '*', '',100);
  141. if (empty($order_list)) break;
  142. foreach ($order_list as $order_info) {
  143. $result = $logic_vr_order->changeOrderStateCancel($order_info,'system','超期未支付系统自动关闭订单',false);
  144. }
  145. if (!$result['state']) {
  146. $this->log('虚拟订单超期未支付关闭失败SN:'.$order_info['order_sn']); $_break = true; break;
  147. }
  148. }
  149. }
  150. /**
  151. * 订单自动完成
  152. */
  153. private function _order_auto_complete()
  154. {
  155. //虚拟订单过使用期自动完成
  156. $_break = false;
  157. $model_order = Model('vr_order');
  158. $logic_order = Logic('vr_order');
  159. $condition = array();
  160. $condition['order_state'] = ORDER_STATE_PAY;
  161. $condition['vr_indate'] = array('lt',time());
  162. //分批,每批处理100个订单,最多处理5W个订单
  163. for ($i = 0; $i < 500; $i++)
  164. {
  165. if ($_break) {
  166. break;
  167. }
  168. $order_list = $model_order->getOrderList($condition, '', 'order_id,order_sn', 'vr_indate asc', 100);
  169. if (empty($order_list)) break;
  170. foreach ($order_list as $order_info) {
  171. $result = $logic_order->changeOrderStateSuccess($order_info['order_id']);
  172. if (!$result['state']) {
  173. $this->log('虚拟订单过使用期自动完成失败SN:'.$order_info['order_sn']); $_break = true; break;
  174. }
  175. }
  176. }
  177. //实物订单发货后,超期自动收货完成
  178. $_break = false;
  179. $model_order = Model('order');
  180. $logic_order = Logic('order');
  181. $condition = array();
  182. $condition['order_state'] = ORDER_STATE_SEND;
  183. $condition['lock_state'] = 0;
  184. $condition['delay_time'] = array('lt',time() - ORDER_AUTO_RECEIVE_DAY * 86400);
  185. //分批,每批处理100个订单,最多处理5W个订单
  186. for ($i = 0; $i < 500; $i++){
  187. if ($_break) {
  188. break;
  189. }
  190. $order_list = $model_order->getOrderList($condition, '', '*', 'delay_time asc', 100);
  191. if (empty($order_list)) break;
  192. foreach ($order_list as $order_info) {
  193. $result = $logic_order->changeOrderStateReceive($order_info,'system','系统','超期未收货系统自动完成订单');
  194. if (!$result['state']) {
  195. $this->log('实物订单超期未收货自动完成订单失败SN:'.$order_info['order_sn']); $_break = true; break;
  196. }
  197. }
  198. }
  199. }
  200. /**
  201. * 自提订单中,已经关闭订单的,删除
  202. */
  203. private function _order_delivery_cancel_del() {
  204. $model_delivery = Model('delivery_order');
  205. $model_order = Model('order');
  206. for($i = 0; $i < 10; $i++) {
  207. $delivery_list = $model_delivery->getDeliveryOrderDefaultList(array(), '*', 0, 'order_id asc', 100);
  208. if (!empty($delivery_list)) {
  209. $order_ids = array();
  210. foreach ($delivery_list as $k => $v) {
  211. $order_ids[] = $v['order_id'];
  212. }
  213. $condition = array();
  214. $condition['order_state'] = ORDER_STATE_CANCEL;
  215. $condition['order_id'] = array('in',$order_ids);
  216. $order_list = $model_order->getOrderList($condition,'','order_id');
  217. if (!empty($order_list)) {
  218. $order_ids = array();
  219. foreach ($order_list as $k => $v) {
  220. $order_ids[] = $v['order_id'];
  221. }
  222. $del = $model_delivery->delDeliveryOrder(array('order_id'=>array('in',$order_ids)));
  223. if (!del) {
  224. $this->log('删除自提点订单失败');
  225. }
  226. } else {
  227. break;
  228. }
  229. } else {
  230. break;
  231. }
  232. }
  233. }
  234. /**
  235. * 更新订单扩展表中收货人所在省份ID
  236. */
  237. private function _order_reciver_provinceid_update()
  238. {
  239. $model_order = Model('order');
  240. $model_area = Model('area');
  241. //每次最多处理5W个订单
  242. $condition = array();
  243. $condition['reciver_province_id'] = 0;
  244. $condition['reciver_city_id'] = array('neq',0);
  245. for($i = 0; $i < 500; $i++)
  246. {
  247. $order_list = $model_order->getOrderCommonList($condition, 'reciver_city_id','order_id desc', 100);
  248. if (!empty($order_list))
  249. {
  250. $city_ids = array();
  251. foreach ($order_list as $v) {
  252. if (!in_array($v['reciver_city_id'],$city_ids)) {
  253. $city_ids[] = $v['reciver_city_id'];
  254. }
  255. }
  256. $area_list = $model_area->getAreaList(array('area_id'=>array('in',$city_ids)),'area_parent_id,area_id');
  257. if (!empty($area_list))
  258. {
  259. foreach ($area_list as $v) {
  260. $update = $model_order->editOrderCommon(array('reciver_province_id'=>$v['area_parent_id']),array('reciver_city_id'=>$v['area_id']));
  261. if (!$update) {
  262. $this->log('更新订单扩展表中收货人所在省份ID失败');break;
  263. }
  264. }
  265. }
  266. }
  267. else {
  268. break;
  269. }
  270. }
  271. }
  272. /**
  273. * 增加会员积分和经验值
  274. */
  275. private function _add_points()
  276. {
  277. return;
  278. $model_points = Model('points');
  279. $model_exppoints = Model('exppoints');
  280. //24小时之内登录的会员送积分和经验值,每次最多处理5W个会员
  281. $model_member = Model('member');
  282. $condition = array();
  283. $condition['member_login_time'] = array('gt',time() - self::EXE_TIMES);
  284. for($i = 0; $i < 50000; $i=$i+100)
  285. {
  286. $member_list = $model_member->getMemberList($condition, 'member_name,member_id',0,'', "{$i},100");
  287. if (!empty($member_list))
  288. {
  289. foreach ($member_list as $member_info)
  290. {
  291. if (C('points_isuse')) {
  292. $model_points->savePointsLog('login',array('pl_memberid'=>$member_info['member_id'],'pl_membername'=>$member_info['member_name']),true);
  293. }
  294. $model_exppoints->saveExppointsLog('login',array('exp_memberid'=>$member_info['member_id'],'exp_membername'=>$member_info['member_name']),true);
  295. }
  296. }
  297. else {
  298. break;
  299. }
  300. }
  301. //24小时之内注册的会员送积分,每次最多处理5W个会员
  302. if (C('points_isuse'))
  303. {
  304. $condition = array();
  305. $condition['member_time'] = array('gt',time() - self::EXE_TIMES);
  306. for($i = 0; $i < 50000; $i=$i+100)
  307. {
  308. $member_list = $model_member->getMemberList($condition, 'member_name,member_id',0,'member_id desc', "{$i},100");
  309. if (!empty($member_list)) {
  310. foreach ($member_list as $member_info) {
  311. $model_points->savePointsLog('regist',array('pl_memberid'=>$member_info['member_id'],'pl_membername'=>$member_info['member_name']),true);
  312. }
  313. } else {
  314. break;
  315. }
  316. }
  317. }
  318. //24小时之内完成了实物订单送积分和经验值,每次最多处理5W个订单
  319. $model_order = Model('order');
  320. $condition = array();
  321. $condition['finnshed_time'] = array('gt',time() - self::EXE_TIMES);
  322. for($i = 0; $i < 50000; $i=$i+100)
  323. {
  324. $order_list = $model_order->getOrderList($condition,'','buyer_name,buyer_id,order_amount,order_sn,order_id','', "{$i},100");
  325. if (!empty($order_list))
  326. {
  327. foreach ($order_list as $order_info) {
  328. if (C('points_isuse')) {
  329. $model_points->savePointsLog('order',array('pl_memberid'=>$order_info['buyer_id'],'pl_membername'=>$order_info['buyer_name'],'orderprice'=>$order_info['order_amount'],'order_sn'=>$order_info['order_sn'],'order_id'=>$order_info['order_id']),true);
  330. }
  331. $model_exppoints->saveExppointsLog('order',array('exp_memberid'=>$order_info['buyer_id'],'exp_membername'=>$order_info['buyer_name'],'orderprice'=>$order_info['order_amount'],'order_sn'=>$order_info['order_sn'],'order_id'=>$order_info['order_id']),true);
  332. }
  333. } else {
  334. break;
  335. }
  336. }
  337. //24小时之内完成了实物订单送积分和经验值,每次最多处理5W个订单
  338. $model_order = Model('vr_order');
  339. $condition = array();
  340. $condition['finnshed_time'] = array('gt',time() - self::EXE_TIMES);
  341. for($i = 0; $i < 50000; $i=$i+100)
  342. {
  343. $order_list = $model_order->getOrderList($condition,'','buyer_name,buyer_id,order_amount,order_sn,order_id','', "{$i},100");
  344. if (!empty($order_list))
  345. {
  346. foreach ($order_list as $order_info) {
  347. if (C('points_isuse')) {
  348. $model_points->savePointsLog('order',array('pl_memberid'=>$order_info['buyer_id'],'pl_membername'=>$order_info['buyer_name'],'orderprice'=>$order_info['order_amount'],'order_sn'=>$order_info['order_sn'],'order_id'=>$order_info['order_id']),true);
  349. }
  350. $model_exppoints->saveExppointsLog('order',array('exp_memberid'=>$order_info['buyer_id'],'exp_membername'=>$order_info['buyer_name'],'orderprice'=>$order_info['order_amount'],'order_sn'=>$order_info['order_sn'],'order_id'=>$order_info['order_id']),true);
  351. }
  352. } else {
  353. break;
  354. }
  355. }
  356. }
  357. /**
  358. * 代金券即将过期提醒
  359. */
  360. private function _voucher_will_expire()
  361. {
  362. $time_start = mktime(0, 0, 0, date("m") , date("d")+self::VOUCHER_INTERVAL, date("Y"));
  363. $time_stop = $time_start + self::EXE_TIMES - 1;
  364. $where = array();
  365. $where['voucher_end_date'] = array(array('egt', $time_start), array('elt', $time_stop), 'and');
  366. $list = Model('voucher')->getVoucherUnusedList($where);
  367. if (!empty($list))
  368. {
  369. foreach ($list as $val) {
  370. $param = array();
  371. $param['code'] = 'voucher_will_expire';
  372. $param['member_id'] = $val['voucher_owner_id'];
  373. $param['param'] = array(
  374. 'indate' => date('Y-m-d H:i:s', $val['voucher_end_date']),
  375. 'voucher_url' => urlShop('member_voucher', 'index')
  376. );
  377. QueueClient::push('sendMemberMsg', $param);
  378. }
  379. }
  380. }
  381. /**
  382. * 虚拟兑换码即将过期提醒
  383. */
  384. private function _vr_code_will_expire() {
  385. $time_start = mktime(0, 0, 0, date("m") , date("d")+self::VR_CODE_INTERVAL, date("Y"));
  386. $time_stop = $time_start + self::EXE_TIMES - 1;
  387. $where = array();
  388. $where['vr_indate'] = array(array('egt', $time_start), array('elt', $time_stop), 'and');
  389. $list = Model('vr_order')->getCodeUnusedList($where);
  390. if (!empty($list)) {
  391. foreach ($list as $val) {
  392. $param = array();
  393. $param['code'] = 'vr_code_will_expire';
  394. $param['member_id'] = $val['buyer_id'];
  395. $param['param'] = array(
  396. 'indate' => date('Y-m-d H:i:s', $val['vr_indate']),
  397. 'vr_order_url' => urlShop('member_vr_order', 'index')
  398. );
  399. QueueClient::push('sendMemberMsg', $param);
  400. }
  401. }
  402. }
  403. /**
  404. * 订单超期后不允许评价
  405. */
  406. private function _order_eval_expire_update() {
  407. //实物订单超期未评价自动更新状态,每次最多更新1000个订单
  408. $model_order = Model('order');
  409. $condition = array();
  410. $condition['order_state'] = ORDER_STATE_SUCCESS;
  411. $condition['evaluation_state'] = 0;
  412. $condition['finnshed_time'] = array('lt',time() - self::ORDER_EVALUATE_TIME);
  413. $update = array();
  414. $update['evaluation_state'] = 2;
  415. $update = $model_order->editOrder($update,$condition,1000);
  416. if (!$update) {
  417. $this->log('更新实物订单超期不能评价失败'); return;
  418. }
  419. //虚拟订单超期未评价自动更新状态,每次最多更新1000个订单
  420. $model_order = Model('vr_order');
  421. $condition = array();
  422. $condition['order_state'] = ORDER_STATE_SUCCESS;
  423. $condition['evaluation_state'] = 0;
  424. $condition['use_state'] = 1;
  425. $condition['finnshed_time'] = array('lt',time() - self::ORDER_EVALUATE_TIME);
  426. $update = array();
  427. $update['evaluation_state'] = 2;
  428. $update = $model_order->editOrder($update,$condition,1000);
  429. if (!$update) {
  430. $this->log('更新虚拟订单超期不能评价失败'); return;
  431. }
  432. }
  433. /**
  434. * 更新商品访问量(redis)
  435. */
  436. private function _goods_click_update() {
  437. $data = rcache('updateRedisDate', 'goodsClick');
  438. foreach ($data as $key => $val) {
  439. Model('goods')->editGoodsById(array('goods_click' => array('exp', 'goods_click +'.$val)), $key);
  440. }
  441. dcache('updateRedisDate', 'goodsClick');
  442. }
  443. /**
  444. * 更新商品促销到期状态(目前只有满即送)
  445. */
  446. private function _goods_promotion_state_update() {
  447. //满即送过期
  448. Model('p_mansong')->editExpireMansong();
  449. }
  450. /**
  451. * 商品到货通知提醒
  452. */
  453. private function _arrival_notice()
  454. {
  455. $strat_time = strtotime("-60 day"); // 只通知最近60天的记录
  456. $mod_anotice = Model('arrival_notice');
  457. // 删除60天之前的记录
  458. $mod_anotice->delArrivalNotice(array('an_addtime' => array('lt', $strat_time), 'an_type' => 1));
  459. $count = $mod_anotice->getArrivalNoticeCount(array());
  460. $times = ceil($count/self::ARRIVAL_NOTICE_NUM);
  461. if ($times == 0) return false;
  462. for ($i = 0; $i <= $times; $i++)
  463. {
  464. $notice_list = $mod_anotice->getArrivalNoticeList(array(), '*', $i.','.self::ARRIVAL_NOTICE_NUM);
  465. if (empty($notice_list)) continue;
  466. // 查询商品是否已经上架
  467. $goodsid_array = array();
  468. foreach ($notice_list as $val) {
  469. $goodsid_array[] = $val['goods_id'];
  470. }
  471. $goodsid_array = array_unique($goodsid_array);
  472. $goods_list = Model('goods')->getGoodsOnlineList(array('goods_id' => array('in', $goodsid_array), 'goods_storage' => array('gt', 0)), 'goods_id');
  473. if (empty($goods_list)) continue;
  474. // 需要通知到货的商品
  475. $goodsid_array = array();
  476. foreach ($goods_list as $val) {
  477. $goodsid_array[] = $val['goods_id'];
  478. }
  479. // 根据商品id重新查询需要通知的列表
  480. $notice_list = $mod_anotice->getArrivalNoticeList(array('goods_id' => array('in', $goodsid_array)), '*');
  481. if (empty($notice_list)) continue;
  482. foreach ($notice_list as $val)
  483. {
  484. $param = array();
  485. $param['code'] = 'arrival_notice';
  486. $param['member_id'] = $val['member_id'];
  487. $param['param'] = array(
  488. 'goods_name' => $val['goods_name'],
  489. 'goods_url' => urlShop('goods', 'index', array('goods_id' => $val['goods_id']))
  490. );
  491. $param['number'] = array('mobile' => $val['an_mobile'], 'email' => $val['an_email']);
  492. $param['sms_param'] = array('goods_name' => $val['goods_name']);
  493. QueueClient::push('sendMemberMsg', $param);
  494. }
  495. // 清楚发送成功的数据
  496. $mod_anotice->delArrivalNotice(array('goods_id' => array('in', $goodsid_array)));
  497. }
  498. }
  499. /**
  500. * 将缓存中的浏览记录存入数据库中,并删除30天前的浏览历史
  501. */
  502. private function _goods_browse_update(){
  503. $model = Model('goods_browse');
  504. //将cache中的记录存入数据库
  505. if (C('cache_open')){//如果浏览记录已经存入了缓存中,则将其整理到数据库中
  506. //上次更新缓存的时间
  507. $latest_record = $model->getGoodsbrowseOne(array(),'','browsetime desc');
  508. $starttime = ($t = intval($latest_record['browsetime']))?$t:0;
  509. $monthago = strtotime(date('Y-m-d',time())) - 86400*30;
  510. $model_member = Model('member');
  511. //查询会员信息总条数
  512. $countnum = $model_member->getMemberCount(array());
  513. $eachnum = 100;
  514. for ($i=0; $i<$countnum; $i+=$eachnum){//每次查询100条
  515. $member_list = $model_member->getMemberList(array(), '*', 0, 'member_id asc', "$i,$eachnum");
  516. foreach ((array)$member_list as $k=>$v){
  517. $insert_arr = array();
  518. $goodsid_arr = array();
  519. //生成缓存的键值
  520. $hash_key = $v['member_id'];
  521. $browse_goodsid = rcache($hash_key,'goodsbrowse','goodsid');
  522. if ($browse_goodsid) {
  523. //删除缓存中多余的浏览历史记录,仅保留最近的30条浏览历史,先取出最近30条浏览历史的商品ID
  524. $cachegoodsid_arr = $browse_goodsid['goodsid']?unserialize($browse_goodsid['goodsid']):array();
  525. unset($browse_goodsid['goodsid']);
  526. if ($cachegoodsid_arr){
  527. $cachegoodsid_arr = array_slice($cachegoodsid_arr,-30,30,true);
  528. }
  529. //处理存入数据库的浏览历史缓存信息
  530. $_cache = rcache($hash_key, 'goodsbrowse');
  531. foreach((array)$_cache as $c_k=>$c_v){
  532. $c_v = unserialize($c_v);
  533. if ($c_v['browsetime'] >= $starttime){//如果 缓存中的数据未更新到数据库中(即添加时间大于上次更新到数据库中的数据时间)则将数据更新到数据库中
  534. $tmp_arr = array();
  535. $tmp_arr['goods_id'] = $c_v['goods_id'];
  536. $tmp_arr['member_id'] = $v['member_id'];
  537. $tmp_arr['browsetime'] = $c_v['browsetime'];
  538. $tmp_arr['gc_id'] = $c_v['gc_id'];
  539. $tmp_arr['gc_id_1'] = $c_v['gc_id_1'];
  540. $tmp_arr['gc_id_2'] = $c_v['gc_id_2'];
  541. $tmp_arr['gc_id_3'] = $c_v['gc_id_3'];
  542. $insert_arr[] = $tmp_arr;
  543. $goodsid_arr[] = $c_v['goods_id'];
  544. }
  545. //除了最近的30条浏览历史之外多余的浏览历史记录或者30天之前的浏览历史从缓存中删除
  546. if (!in_array($c_v['goods_id'], $cachegoodsid_arr) || $c_v['browsetime'] < $monthago){
  547. unset($_cache[$c_k]);
  548. }
  549. }
  550. //删除已经存在的该商品浏览记录
  551. if ($goodsid_arr){
  552. $model->delGoodsbrowse(array('member_id'=>$v['member_id'],'goods_id'=>array('in',$goodsid_arr)));
  553. }
  554. //将缓存中的浏览历史存入数据库
  555. if ($insert_arr){
  556. $model->addGoodsbrowseAll($insert_arr);
  557. }
  558. //重新赋值浏览历史缓存
  559. dcache($hash_key, 'goodsbrowse');
  560. $_cache['goodsid'] = serialize($cachegoodsid_arr);
  561. wcache($hash_key,$_cache,'goodsbrowse');
  562. }
  563. }
  564. }
  565. }
  566. //删除30天前的浏览历史
  567. $model->delGoodsbrowse(array('browsetime'=>array('lt',$monthago)));
  568. }
  569. /**
  570. * 缓存订单及订单商品相关数据
  571. */
  572. private function _order_goods_cache(){
  573. $model = Model('stat');
  574. //查询最后统计的记录
  575. $latest_record = $model->table('stat_ordergoods')->order('stat_updatetime desc,rec_id desc')->find();
  576. $stime = 0;
  577. if ($latest_record){
  578. $start_time = strtotime(date('Y-m-d',$latest_record['stat_updatetime']));
  579. } else {
  580. $start_time = strtotime(date('Y-m-d',strtotime(C('setup_date'))));//从系统的安装时间开始统计
  581. }
  582. for ($stime = $start_time; $stime < time(); $stime = $stime+86400){
  583. $etime = $stime + 86400 - 1;
  584. //避免重复统计,开始时间必须大于最后一条记录的记录时间
  585. $search_stime = $latest_record['stat_updatetime'] > $stime?$latest_record['stat_updatetime']:$stime;
  586. //统计一天的数据,如果结束时间大于当前时间,则结束时间为当前时间,避免因为查询时间的延迟造成数据遗落
  587. $search_etime = ($t = ($stime + 86400 - 1)) > time() ? time() : ($stime + 86400 - 1);
  588. //查询时间段内新订单或者更新过的订单,在缓存表中需要将新订单和更新过的订单进行重新缓存
  589. $where = array();
  590. $where['log_time'] = array('between',array($search_stime,$search_etime));
  591. //查询记录总条数
  592. $countnum_arr = $model->table('order_log')->field('COUNT(DISTINCT order_id) as countnum')->where($where)->find();
  593. $countnum = intval($countnum_arr['countnum']);
  594. for ($i=0; $i<$countnum; $i+=100){//每次查询100条
  595. $orderlog_list = array();
  596. $orderlog_list = $model->table('order_log')->field('DISTINCT order_id')->where($where)->limit($i.',100')->select();
  597. if ($orderlog_list){
  598. //店铺ID数组
  599. $storeid_arr = array();
  600. //商品ID数组
  601. $goodsid_arr = array();
  602. //商品公共表ID数组
  603. $goods_commonid_arr = array();
  604. //订单ID数组
  605. $orderid_arr = array();
  606. //整理需要缓存的订单ID
  607. foreach ((array)$orderlog_list as $k=>$v){
  608. $orderid_arr[] = $v['order_id'];
  609. }
  610. unset($orderlog_list);
  611. //查询订单数据
  612. $field = 'order_id,order_sn,store_id,buyer_id,buyer_name,add_time,payment_code,order_amount,shipping_fee,evaluation_state,order_state,refund_state,refund_amount,order_from';
  613. $order_list_tmp = $model->table('order')->field($field)->where(array('order_id'=>array('in',$orderid_arr)))->select();
  614. $order_list = array();
  615. foreach ((array)$order_list_tmp as $k=>$v){
  616. //判读订单是否计入统计(在线支付订单已支付或者经过退款的取消订单或者货到付款订单订单已成功)
  617. $v['order_isvalid'] = 0;
  618. if ($v['payment_code'] != 'offline' && $v['order_state'] != ORDER_STATE_NEW && $v['order_state'] != ORDER_STATE_CANCEL){//在线支付并且已支付并且未取消
  619. $v['order_isvalid'] = 1;
  620. } elseif ($v['order_state'] == ORDER_STATE_CANCEL && $v['refund_state'] != 0) {//经过退款的取消订单
  621. $v['order_isvalid'] = 1;
  622. } elseif ($v['payment_code'] == 'offline' && $v['order_state'] == ORDER_STATE_SUCCESS) {//货到付款订单,订单成功之后才计入统计
  623. $v['order_isvalid'] = 1;
  624. }
  625. $order_list[$v['order_id']] = $v;
  626. $storeid_arr[] = $v['store_id'];
  627. }
  628. unset($order_list_tmp);
  629. //查询订单扩展数据
  630. $field = 'order_id,reciver_province_id';
  631. $order_common_list_tmp = $model->table('order_common')->field($field)->where(array('order_id'=>array('in',$orderid_arr)))->select();
  632. $order_common_list = array();
  633. foreach ((array)$order_common_list_tmp as $k=>$v){
  634. $order_common_list[$v['order_id']] = $v;
  635. }
  636. unset($order_common_list_tmp);
  637. //查询店铺信息
  638. $field = 'store_id,store_name,grade_id,sc_id';
  639. $store_list_tmp = $model->table('store')->field($field)->where(array('store_id'=>array('in',$storeid_arr)))->select();
  640. $store_list = array();
  641. foreach ((array)$store_list_tmp as $k=>$v){
  642. $store_list[$v['store_id']] = $v;
  643. }
  644. unset($store_list_tmp);
  645. //查询订单商品
  646. $field = 'rec_id,order_id,goods_id,goods_name,goods_price,goods_num,goods_image,goods_pay_price,store_id,buyer_id,goods_type,promotions_id,commis_rate,gc_id';
  647. $ordergoods_list = $model->table('order_goods')->field($field)->where(array('order_id'=>array('in',$orderid_arr)))->select();
  648. foreach ((array)$ordergoods_list as $k=>$v){
  649. $goodsid_arr[] = $v['goods_id'];
  650. }
  651. //查询商品信息
  652. $field = 'goods_id,goods_commonid,goods_price,goods_serial,gc_id,gc_id_1,gc_id_2,gc_id_3,goods_image';
  653. $goods_list_tmp = $model->table('goods')->field($field)->where(array('goods_id'=>array('in',$goodsid_arr)))->select();
  654. foreach ((array)$goods_list_tmp as $k=>$v){
  655. $goods_commonid_arr[] = $v['goods_commonid'];
  656. }
  657. //查询商品公共信息
  658. $field = 'goods_commonid,goods_name,brand_id,brand_name';
  659. $goods_common_list_tmp = $model->table('goods_common')->field($field)->where(array('goods_commonid'=>array('in',$goods_commonid_arr)))->select();
  660. $goods_common_list = array();
  661. foreach ((array)$goods_common_list_tmp as $k=>$v){
  662. $goods_common_list[$v['goods_commonid']] = $v;
  663. }
  664. unset($goods_common_list_tmp);
  665. //处理商品数组
  666. $goods_list = array();
  667. foreach ((array)$goods_list_tmp as $k=>$v){
  668. $v['goods_commonname'] = $goods_common_list[$v['goods_commonid']]['goods_name'];
  669. $v['brand_id'] = $goods_common_list[$v['goods_commonid']]['brand_id'];
  670. $v['brand_name'] = $goods_common_list[$v['goods_commonid']]['brand_name'];
  671. $goods_list[$v['goods_id']] = $v;
  672. }
  673. unset($goods_list_tmp);
  674. //查询订单缓存是否存在,存在则删除
  675. $model->table('stat_ordergoods')->where(array('order_id'=>array('in',$orderid_arr)))->delete();
  676. //查询订单缓存是否存在,存在则删除
  677. $model->table('stat_order')->where(array('order_id'=>array('in',$orderid_arr)))->delete();
  678. //整理新增数据
  679. $ordergoods_insert_arr = array();
  680. foreach ((array)$ordergoods_list as $k=>$v){
  681. $tmp = array();
  682. $tmp['rec_id'] = $v['rec_id'];
  683. $tmp['stat_updatetime'] = $search_etime;
  684. $tmp['order_id'] = $v['order_id'];
  685. $tmp['order_sn'] = $order_list[$v['order_id']]['order_sn'];
  686. $tmp['order_add_time'] = $order_list[$v['order_id']]['add_time'];
  687. $tmp['payment_code'] = $order_list[$v['order_id']]['payment_code'];
  688. $tmp['order_amount'] = $order_list[$v['order_id']]['order_amount'];
  689. $tmp['shipping_fee'] = $order_list[$v['order_id']]['shipping_fee'];
  690. $tmp['evaluation_state'] = $order_list[$v['order_id']]['evaluation_state'];
  691. $tmp['order_state'] = $order_list[$v['order_id']]['order_state'];
  692. $tmp['refund_state'] = $order_list[$v['order_id']]['refund_state'];
  693. $tmp['refund_amount'] = $order_list[$v['order_id']]['refund_amount'];
  694. $tmp['order_from'] = $order_list[$v['order_id']]['order_from'];
  695. $tmp['order_isvalid'] = $order_list[$v['order_id']]['order_isvalid'];
  696. $tmp['reciver_province_id'] = $order_common_list[$v['order_id']]['reciver_province_id'];
  697. $tmp['store_id'] = $v['store_id'];
  698. $tmp['store_name'] = $store_list[$v['store_id']]['store_name'];
  699. $tmp['grade_id'] = $store_list[$v['store_id']]['grade_id'];
  700. $tmp['sc_id'] = $store_list[$v['store_id']]['sc_id'];
  701. $tmp['buyer_id'] = $order_list[$v['order_id']]['buyer_id'];
  702. $tmp['buyer_name'] = $order_list[$v['order_id']]['buyer_name'];
  703. $tmp['goods_id'] = $v['goods_id'];
  704. $tmp['goods_name'] = $v['goods_name'];
  705. $tmp['goods_commonid'] = intval($goods_list[$v['goods_id']]['goods_commonid']);
  706. $tmp['goods_commonname'] = ($t = $goods_list[$v['goods_id']]['goods_commonname'])?$t:'';
  707. $tmp['gc_id'] = intval($goods_list[$v['goods_id']]['gc_id']);
  708. $tmp['gc_parentid_1'] = intval($goods_list[$v['goods_id']]['gc_id_1']);
  709. $tmp['gc_parentid_2'] = intval($goods_list[$v['goods_id']]['gc_id_2']);
  710. $tmp['gc_parentid_3'] = intval($goods_list[$v['goods_id']]['gc_id_3']);
  711. $tmp['brand_id'] = intval($goods_list[$v['goods_id']]['brand_id']);
  712. $tmp['brand_name'] = ($t = $goods_list[$v['goods_id']]['brand_name'])?$t:'';
  713. $tmp['goods_serial'] = ($t = $goods_list[$v['goods_id']]['goods_serial'])?$t:'';
  714. $tmp['goods_price'] = $v['goods_price'];
  715. $tmp['goods_num'] = $v['goods_num'];
  716. $tmp['goods_image'] = $goods_list[$v['goods_id']]['goods_image'];
  717. $tmp['goods_pay_price'] = $v['goods_pay_price'];
  718. $tmp['goods_type'] = $v['goods_type'];
  719. $tmp['promotions_id'] = $v['promotions_id'];
  720. $tmp['commis_rate'] = $v['commis_rate'];
  721. $ordergoods_insert_arr[] = $tmp;
  722. }
  723. $model->table('stat_ordergoods')->insertAll($ordergoods_insert_arr);
  724. $order_insert_arr = array();
  725. foreach ((array)$order_list as $k=>$v){
  726. $tmp = array();
  727. $tmp['order_id'] = $v['order_id'];
  728. $tmp['order_sn'] = $v['order_sn'];
  729. $tmp['order_add_time'] = $v['add_time'];
  730. $tmp['payment_code'] = $v['payment_code'];
  731. $tmp['order_amount'] = $v['order_amount'];
  732. $tmp['shipping_fee'] = $v['shipping_fee'];
  733. $tmp['evaluation_state'] = $v['evaluation_state'];
  734. $tmp['order_state'] = $v['order_state'];
  735. $tmp['refund_state'] = $v['refund_state'];
  736. $tmp['refund_amount'] = $v['refund_amount'];
  737. $tmp['order_from'] = $v['order_from'];
  738. $tmp['order_isvalid'] = $v['order_isvalid'];
  739. $tmp['reciver_province_id'] = $order_common_list[$v['order_id']]['reciver_province_id'];
  740. $tmp['store_id'] = $v['store_id'];
  741. $tmp['store_name'] = $store_list[$v['store_id']]['store_name'];
  742. $tmp['grade_id'] = $store_list[$v['store_id']]['grade_id'];
  743. $tmp['sc_id'] = $store_list[$v['store_id']]['sc_id'];
  744. $tmp['buyer_id'] = $v['buyer_id'];
  745. $tmp['buyer_name'] = $v['buyer_name'];
  746. $order_insert_arr[] = $tmp;
  747. }
  748. $model->table('stat_order')->insertAll($order_insert_arr);
  749. }
  750. }
  751. }
  752. }
  753. /**
  754. * 会员相关数据统计
  755. */
  756. private function _member_stat()
  757. {
  758. $model = Model('stat');
  759. //查询最后统计的记录
  760. $latest_record = $model->getOneStatmember(array(), '', 'statm_id desc');
  761. $stime = 0;
  762. if ($latest_record){
  763. $start_time = strtotime(date('Y-m-d',$latest_record['statm_updatetime']));
  764. } else {
  765. $start_time = strtotime(date('Y-m-d',strtotime(C('setup_date'))));//从系统的安装时间开始统计
  766. }
  767. $j = 1;
  768. for ($stime = $start_time; $stime < time(); $stime = $stime+86400){
  769. //数据库更新数据数组
  770. $insert_arr = array();
  771. $update_arr = array();
  772. $etime = $stime + 86400 - 1;
  773. //避免重复统计,开始时间必须大于最后一条记录的记录时间
  774. $search_stime = $latest_record['statm_updatetime'] > $stime ? $latest_record['statm_updatetime'] : $stime;
  775. //统计一天的数据,如果结束时间大于当前时间,则结束时间为当前时间,避免因为查询时间的延迟造成数据遗落
  776. $search_etime = ($t = ($stime + 86400 - 1)) > time() ? time() : ($stime + 86400 - 1);
  777. //统计订单下单量和下单金额
  778. $field = ' order.order_id,add_time,buyer_id,buyer_name,order_amount';
  779. $where = array();
  780. $where['order.order_state'] = array('neq',ORDER_STATE_NEW);//去除未支付订单
  781. $where['order.refund_state'] = array('exp',"!(order.order_state = '".ORDER_STATE_CANCEL."' and order.refund_state = 0)");//没有参与退款的取消订单,不记录到统计中
  782. $where['order_log.log_time'] = array('between',array($search_stime,$search_etime));//按照订单付款的操作时间统计
  783. //货到付款当交易成功进入统计,非货到付款当付款后进入统计
  784. $where['payment_code'] = array('exp',"(order.payment_code='offline' and order_log.log_orderstate = '".ORDER_STATE_SUCCESS."') or (order.payment_code<>'offline' and order_log.log_orderstate = '".ORDER_STATE_PAY."' )");
  785. $orderlist_tmp = $model->statByOrderLog($where, $field, 0, 0, 'order_id');//此处由于底层的限制,仅能查询1000条,如果日下单量大于1000,则需要limit的支持
  786. $order_list = array();
  787. $orderid_list = array();
  788. foreach ((array)$orderlist_tmp as $k=>$v){
  789. $addtime = strtotime(date('Y-m-d',$v['add_time']));
  790. if ($addtime != $stime){//订单如果隔天支付的话,需要进行统计数据更新
  791. $update_arr[$addtime][$v['buyer_id']]['statm_membername'] = $v['buyer_name'];
  792. $update_arr[$addtime][$v['buyer_id']]['statm_ordernum'] = intval($update_arr[$addtime][$v['buyer_id']]['statm_ordernum'])+1;
  793. $update_arr[$addtime][$v['buyer_id']]['statm_orderamount'] = floatval($update_arr[$addtime][$v['buyer_id']]['statm_orderamount']) + (($t = floatval($v['order_amount'])) > 0?$t:0);
  794. } else {
  795. $order_list[$v['buyer_id']]['buyer_name'] = $v['buyer_name'];
  796. $order_list[$v['buyer_id']]['ordernum'] = intval($order_list[$v['buyer_id']]['ordernum']) + 1;
  797. $order_list[$v['buyer_id']]['orderamount'] = floatval($order_list[$v['buyer_id']]['orderamount']) + (($t = floatval($v['order_amount'])) > 0?$t:0);
  798. }
  799. //记录订单ID数组
  800. $orderid_list[] = $v['order_id'];
  801. }
  802. //统计下单商品件数
  803. if ($orderid_list){
  804. $field = ' add_time,order.buyer_id,order.buyer_name,goods_num ';
  805. $where = array();
  806. $where['order.order_id'] = array('in',$orderid_list);
  807. $ordergoods_tmp = $model->statByOrderGoods($where, $field, 0, 0, 'order.order_id');
  808. $ordergoods_list = array();
  809. foreach ((array)$ordergoods_tmp as $k=>$v){
  810. $addtime = strtotime(date('Y-m-d',$v['add_time']));
  811. if ($addtime != $stime){//订单如果隔天支付的话,需要进行统计数据更新
  812. $update_arr[$addtime][$v['buyer_id']]['statm_goodsnum'] = intval($update_arr[$addtime][$v['buyer_id']]['statm_goodsnum']) + (($t = floatval($v['goods_num'])) > 0?$t:0);
  813. } else {
  814. $ordergoods_list[$v['buyer_id']]['goodsnum'] = $ordergoods_list[$v['buyer_id']]['goodsnum'] + (($t = floatval($v['goods_num'])) > 0?$t:0);
  815. }
  816. }
  817. }
  818. //统计的预存款记录
  819. $field = ' lg_member_id,lg_member_name,SUM(IF(lg_av_amount>=0,lg_av_amount,0)) as predincrease, SUM(IF(lg_av_amount<=0,lg_av_amount,0)) as predreduce ';
  820. $where = array();
  821. $where['lg_add_time'] = array('between',array($stime,$etime));
  822. $predeposit_tmp = $model->getPredepositInfo($where, $field, 0, 'lg_member_id', 0, 'lg_member_id');
  823. $predeposit_list = array();
  824. foreach ((array)$predeposit_tmp as $k=>$v){
  825. $predeposit_list[$v['lg_member_id']] = $v;
  826. }
  827. //统计的积分记录
  828. $field = ' pl_memberid,pl_membername,SUM(IF(pl_points>=0,pl_points,0)) as pointsincrease, SUM(IF(pl_points<=0,pl_points,0)) as pointsreduce ';
  829. $where = array();
  830. $where['pl_addtime'] = array('between',array($stime,$etime));
  831. $points_tmp = $model->statByPointslog($where, $field, 0, 0, '', 'pl_memberid');
  832. $points_list = array();
  833. foreach ((array)$points_tmp as $k=>$v){
  834. $points_list[$v['pl_memberid']] = $v;
  835. }
  836. //处理需要更新的数据
  837. foreach ((array)$update_arr as $k=>$v){
  838. foreach ($v as $m_k=>$m_v){
  839. //查询记录是否存在
  840. $statmember_info = $model->getOneStatmember(array('statm_time'=>$k,'statm_memberid'=>$m_k));
  841. if ($statmember_info){
  842. $m_v['statm_ordernum'] = intval($statmember_info['statm_ordernum']) + $m_v['statm_ordernum'];
  843. $m_v['statm_orderamount'] = floatval($statmember_info['statm_ordernum']) + $m_v['statm_orderamount'];
  844. $m_v['statm_updatetime'] = $search_etime;
  845. $model->updateStatmember(array('statm_time'=>$k,'statm_memberid'=>$m_k),$m_v);
  846. } else {
  847. $tmp = array();
  848. $tmp['statm_memberid'] = $m_k;
  849. $tmp['statm_membername'] = $m_v['statm_membername'];
  850. $tmp['statm_time'] = $k;
  851. $tmp['statm_updatetime'] = $search_etime;
  852. $tmp['statm_ordernum'] = ($t = intval($m_v['statm_ordernum'])) > 0?$t:0;
  853. $tmp['statm_orderamount'] = ($t = floatval($m_v['statm_orderamount']))>0?$t:0;
  854. $tmp['statm_goodsnum'] = ($t = intval($m_v['statm_goodsnum']))?$t:0;
  855. $tmp['statm_predincrease'] = 0;
  856. $tmp['statm_predreduce'] = 0;
  857. $tmp['statm_pointsincrease'] = 0;
  858. $tmp['statm_pointsreduce'] = 0;
  859. $insert_arr[] = $tmp;
  860. }
  861. unset($statmember_info);
  862. }
  863. }
  864. //处理获得所有会员ID数组
  865. $memberidarr_order = $order_list?array_keys($order_list):array();
  866. $memberidarr_ordergoods = $ordergoods_list?array_keys($ordergoods_list):array();
  867. $memberidarr_predeposit = $predeposit_list?array_keys($predeposit_list):array();
  868. $memberidarr_points = $points_list?array_keys($points_list):array();
  869. $memberid_arr = array_merge($memberidarr_order,$memberidarr_ordergoods,$memberidarr_predeposit,$memberidarr_points);
  870. //查询会员信息
  871. $memberid_list = Model('member')->getMemberList(array('member_id'=>array('in',$memberid_arr)), '*', 0);
  872. //查询记录是否存在
  873. $statmemberlist_tmp = $model->statByStatmember(array('statm_time'=>$stime));
  874. $statmemberlist = array();
  875. foreach ((array)$statmemberlist_tmp as $k=>$v){
  876. $statmemberlist[$v['statm_memberid']] = $v;
  877. }
  878. foreach ((array)$memberid_list as $k=>$v){
  879. $tmp = array();
  880. $tmp['statm_memberid'] = $v['member_id'];
  881. $tmp['statm_membername'] = $v['member_name'];
  882. $tmp['statm_time'] = $stime;
  883. $tmp['statm_updatetime'] = $search_etime;
  884. //因为记录可能已经存在,所以加上之前的统计记录
  885. $tmp['statm_ordernum'] = intval($statmemberlist[$tmp['statm_memberid']]['statm_ordernum']) + (($t = intval($order_list[$tmp['statm_memberid']]['ordernum'])) > 0?$t:0);
  886. $tmp['statm_orderamount'] = floatval($statmemberlist[$tmp['statm_memberid']]['statm_orderamount']) + (($t = floatval($order_list[$tmp['statm_memberid']]['orderamount']))>0?$t:0);
  887. $tmp['statm_goodsnum'] = intval($statmemberlist[$tmp['statm_memberid']]['statm_goodsnum']) + (($t = intval($ordergoods_list[$tmp['statm_memberid']]['goodsnum']))?$t:0);
  888. $tmp['statm_predincrease'] = (($t = floatval($predeposit_list[$tmp['statm_memberid']]['predincrease']))?$t:0);
  889. $tmp['statm_predreduce'] = (($t = floatval($predeposit_list[$tmp['statm_memberid']]['predreduce']))?$t:0);
  890. $tmp['statm_pointsincrease'] = (($t = intval($points_list[$tmp['statm_memberid']]['pointsincrease']))?$t:0);
  891. $tmp['statm_pointsreduce'] = (($t = intval($points_list[$tmp['statm_memberid']]['pointsreduce']))?$t:0);
  892. $insert_arr[] = $tmp;
  893. }
  894. //删除旧的统计数据
  895. $model->delByStatmember(array('statm_time'=>$stime));
  896. $model->table('stat_member')->insertAll($insert_arr);
  897. }
  898. }
  899. private function bonus_expire_notify()
  900. {
  901. notify_helper::onBonusExpire(10,5);
  902. }
  903. }