control.php 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  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. {
  25. if ($if_sql) {
  26. $log = Log::sql_log();
  27. if (!empty($log) && is_array($log)){
  28. $content .= end($log);
  29. }
  30. }
  31. Log::record('queue\\'.$content,Log::RUN);
  32. }
  33. /**
  34. * 更新订单中的佣金比例[多个地方调用,写到父类中]
  35. */
  36. protected function _order_commis_rate_update()
  37. {
  38. //实物订单,每次最多处理50W个商品佣金
  39. $_break = false;
  40. $model_order = Model('order');
  41. $store_bind_class = Model('store_bind_class');
  42. $model_refund_return = Model('refund_return');
  43. for($i = 0; $i < 5000; $i++)
  44. {
  45. if ($_break) {
  46. break;
  47. }
  48. try
  49. {
  50. $trans = new trans_wapper($model_order,__METHOD__);
  51. $goods_list = $model_order->getOrderGoodsList(['commis_rate' => 200], 'rec_id,goods_id,store_id,gc_id', 100, null, '');
  52. if (!empty($goods_list))
  53. {
  54. //$commis_rate_list : store_id => array(gc_id => commis_rate)
  55. $commis_rate_list = $store_bind_class->getStoreGcidCommisRateList($goods_list);
  56. //更新订单商品佣金值
  57. foreach ($goods_list as $v) {
  58. //如果未查到店铺或分类ID,则佣金置0
  59. if (!isset($commis_rate_list[$v['store_id']][$v['gc_id']])) {
  60. $commis_rate = 0;
  61. } else {
  62. $commis_rate = $commis_rate_list[$v['store_id']][$v['gc_id']];
  63. }
  64. $update = $model_order->editOrderGoods(['commis_rate' => $commis_rate], ['rec_id' => $v['rec_id']]);
  65. if (!$update) {
  66. $this->log('更新实物订单商品佣金值失败'); $_break = true; break;
  67. }
  68. $update = $model_refund_return->editRefundReturn(['store_id'=>$v['store_id'],'goods_id'=>$v['goods_id']], ['commis_rate' => $commis_rate]);
  69. if (!$update) {
  70. $this->log('更新实物订单退款佣金值失败'); $_break = true; break;
  71. }
  72. }
  73. } else {
  74. $trans->commit();
  75. break;
  76. }
  77. $trans->commit();
  78. }
  79. catch (Exception $ex) {
  80. $trans->rollback();
  81. }
  82. }
  83. //虚拟订单,每次最多处理50W个商品佣金
  84. $_break = false;
  85. $model_order = Model('vr_order');
  86. $model_vr_refund = Model('vr_refund');
  87. for($i = 0; $i < 5000; $i++)
  88. {
  89. if ($_break) {
  90. break;
  91. }
  92. try
  93. {
  94. $trans = new trans_wapper($model_order,__METHOD__);
  95. $goods_list = $model_order->getOrderList(['commis_rate' => 200],'', 'order_id,store_id,gc_id', '',100);
  96. if (!empty($goods_list))
  97. {
  98. //$commis_rate_list : store_id => array(gc_id => commis_rate)
  99. $commis_rate_list = $store_bind_class->getStoreGcidCommisRateList($goods_list);
  100. //更新订单商品佣金值
  101. foreach ($goods_list as $v)
  102. {
  103. //如果未查到店铺或分类ID,则佣金置0
  104. if (!isset($commis_rate_list[$v['store_id']][$v['gc_id']])) {
  105. $commis_rate = 0;
  106. } else {
  107. $commis_rate = $commis_rate_list[$v['store_id']][$v['gc_id']];
  108. }
  109. $update = $model_order->editOrder(array('commis_rate' => $commis_rate),array('order_id' => $v['order_id']));
  110. if (!$update) {
  111. $this->log('更新虚拟订单商品佣金值失败'); $_break = true; break;
  112. }
  113. $update = $model_order->editOrderCode(array('commis_rate' => $commis_rate),array('order_id' => $v['order_id']));
  114. if (!$update) {
  115. $this->log('更新虚拟订单兑换码佣金值失败'); $_break = true; break;
  116. }
  117. $update = $model_vr_refund->editRefund(array('order_id' => $v['order_id']),array('commis_rate' => $commis_rate));
  118. if (!$update) {
  119. $this->log('更新虚拟订单商品退款佣金值失败'); $_break = true; break;
  120. }
  121. }
  122. }
  123. else {
  124. $trans->commit();
  125. break;
  126. }
  127. $trans->commit();
  128. }
  129. catch (Exception $ex)
  130. {
  131. $trans->rollback();
  132. }
  133. }
  134. }
  135. }