control.php 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. <?php
  2. /**
  3. * 父类
  4. *
  5. *
  6. *
  7. *
  8. */
  9. defined('InShopNC') or exit('Access Invalid!');
  10. class BaseCronControl
  11. {
  12. public function shutdown(){
  13. //exit("shutdown at ".date('Y-m-d H:i:s',time())."\n");
  14. }
  15. public function __construct(){
  16. //register_shutdown_function(array($this,"shutdown"));
  17. }
  18. /**
  19. * 记录日志
  20. * @param unknown $content 日志内容
  21. * @param boolean $if_sql 是否记录SQL
  22. */
  23. protected function log($content, $if_sql = true) {
  24. if ($if_sql) {
  25. $log = Log::read();
  26. if (!empty($log) && is_array($log)){
  27. $content .= end($log);
  28. }
  29. }
  30. Log::record('queue\\'.$content,Log::RUN);
  31. }
  32. /**
  33. * 更新订单中的佣金比例[多个地方调用,写到父类中]
  34. */
  35. protected function _order_commis_rate_update()
  36. {
  37. //实物订单,每次最多处理50W个商品佣金
  38. $_break = false;
  39. $model_order = Model('order');
  40. $store_bind_class = Model('store_bind_class');
  41. $model_refund_return = Model('refund_return');
  42. for($i = 0; $i < 5000; $i++)
  43. {
  44. if ($_break) {
  45. break;
  46. }
  47. try
  48. {
  49. $trans = new trans_wapper($model_order,__METHOD__);
  50. $goods_list = $model_order->getOrderGoodsList(['commis_rate' => 200], 'rec_id,goods_id,store_id,gc_id', 100, null, '');
  51. if (!empty($goods_list))
  52. {
  53. //$commis_rate_list : store_id => array(gc_id => commis_rate)
  54. $commis_rate_list = $store_bind_class->getStoreGcidCommisRateList($goods_list);
  55. //更新订单商品佣金值
  56. foreach ($goods_list as $v) {
  57. //如果未查到店铺或分类ID,则佣金置0
  58. if (!isset($commis_rate_list[$v['store_id']][$v['gc_id']])) {
  59. $commis_rate = 0;
  60. } else {
  61. $commis_rate = $commis_rate_list[$v['store_id']][$v['gc_id']];
  62. }
  63. $update = $model_order->editOrderGoods(['commis_rate' => $commis_rate], ['rec_id' => $v['rec_id']]);
  64. if (!$update) {
  65. $this->log('更新实物订单商品佣金值失败'); $_break = true; break;
  66. }
  67. $update = $model_refund_return->editRefundReturn(['store_id'=>$v['store_id'],'goods_id'=>$v['goods_id']], ['commis_rate' => $commis_rate]);
  68. if (!$update) {
  69. $this->log('更新实物订单退款佣金值失败'); $_break = true; break;
  70. }
  71. }
  72. } else {
  73. $trans->commit();
  74. break;
  75. }
  76. $trans->commit();
  77. }
  78. catch (Exception $ex) {
  79. $trans->rollback();
  80. }
  81. }
  82. //虚拟订单,每次最多处理50W个商品佣金
  83. $_break = false;
  84. $model_order = Model('vr_order');
  85. $model_vr_refund = Model('vr_refund');
  86. for($i = 0; $i < 5000; $i++)
  87. {
  88. if ($_break) {
  89. break;
  90. }
  91. try
  92. {
  93. $trans = new trans_wapper($model_order,__METHOD__);
  94. $goods_list = $model_order->getOrderList(['commis_rate' => 200],'', 'order_id,store_id,gc_id', '',100);
  95. if (!empty($goods_list))
  96. {
  97. //$commis_rate_list : store_id => array(gc_id => commis_rate)
  98. $commis_rate_list = $store_bind_class->getStoreGcidCommisRateList($goods_list);
  99. //更新订单商品佣金值
  100. foreach ($goods_list as $v)
  101. {
  102. //如果未查到店铺或分类ID,则佣金置0
  103. if (!isset($commis_rate_list[$v['store_id']][$v['gc_id']])) {
  104. $commis_rate = 0;
  105. } else {
  106. $commis_rate = $commis_rate_list[$v['store_id']][$v['gc_id']];
  107. }
  108. $update = $model_order->editOrder(array('commis_rate' => $commis_rate),array('order_id' => $v['order_id']));
  109. if (!$update) {
  110. $this->log('更新虚拟订单商品佣金值失败'); $_break = true; break;
  111. }
  112. $update = $model_order->editOrderCode(array('commis_rate' => $commis_rate),array('order_id' => $v['order_id']));
  113. if (!$update) {
  114. $this->log('更新虚拟订单兑换码佣金值失败'); $_break = true; break;
  115. }
  116. $update = $model_vr_refund->editRefund(array('order_id' => $v['order_id']),array('commis_rate' => $commis_rate));
  117. if (!$update) {
  118. $this->log('更新虚拟订单商品退款佣金值失败'); $_break = true; break;
  119. }
  120. }
  121. }
  122. else {
  123. $trans->commit();
  124. break;
  125. }
  126. $trans->commit();
  127. }
  128. catch (Exception $ex)
  129. {
  130. $trans->rollback();
  131. }
  132. }
  133. }
  134. }