control.php 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  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(array('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(array('commis_rate' => $commis_rate),array('rec_id' => $v['rec_id']));
  64. if (!$update) {
  65. $this->log('更新实物订单商品佣金值失败'); $_break = true; break;
  66. }
  67. $update = $model_refund_return->editRefundReturn(array('store_id'=>$v['store_id'],'goods_id'=>$v['goods_id']),array('commis_rate' => $commis_rate));
  68. if (!$update) {
  69. $this->log('更新实物订单退款佣金值失败'); $_break = true; break;
  70. }
  71. }
  72. } else {
  73. break;
  74. }
  75. $trans->commit();
  76. }
  77. catch (Exception $ex) {
  78. $trans->rollback();
  79. }
  80. }
  81. //虚拟订单,每次最多处理50W个商品佣金
  82. $_break = false;
  83. $model_order = Model('vr_order');
  84. $model_vr_refund = Model('vr_refund');
  85. for($i = 0; $i < 5000; $i++)
  86. {
  87. if ($_break) {
  88. break;
  89. }
  90. try
  91. {
  92. $trans = new trans_wapper($model_order,__METHOD__);
  93. $goods_list = $model_order->getOrderList(array('commis_rate' => 200),'', 'order_id,store_id,gc_id', '',100);
  94. if (!empty($goods_list))
  95. {
  96. //$commis_rate_list : store_id => array(gc_id => commis_rate)
  97. $commis_rate_list = $store_bind_class->getStoreGcidCommisRateList($goods_list);
  98. //更新订单商品佣金值
  99. foreach ($goods_list as $v)
  100. {
  101. //如果未查到店铺或分类ID,则佣金置0
  102. if (!isset($commis_rate_list[$v['store_id']][$v['gc_id']])) {
  103. $commis_rate = 0;
  104. } else {
  105. $commis_rate = $commis_rate_list[$v['store_id']][$v['gc_id']];
  106. }
  107. $update = $model_order->editOrder(array('commis_rate' => $commis_rate),array('order_id' => $v['order_id']));
  108. if (!$update) {
  109. $this->log('更新虚拟订单商品佣金值失败'); $_break = true; break;
  110. }
  111. $update = $model_order->editOrderCode(array('commis_rate' => $commis_rate),array('order_id' => $v['order_id']));
  112. if (!$update) {
  113. $this->log('更新虚拟订单兑换码佣金值失败'); $_break = true; break;
  114. }
  115. $update = $model_vr_refund->editRefund(array('order_id' => $v['order_id']),array('commis_rate' => $commis_rate));
  116. if (!$update) {
  117. $this->log('更新虚拟订单商品退款佣金值失败'); $_break = true; break;
  118. }
  119. }
  120. }
  121. else {
  122. break;
  123. }
  124. $trans->commit();
  125. }
  126. catch (Exception $ex)
  127. {
  128. $trans->rollback();
  129. }
  130. }
  131. }
  132. }