date.php 53 KB

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