BaseCron.php 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. <?php
  2. namespace app\crontab\controller;
  3. use app\BaseController;
  4. use think\facade\Log;
  5. /**
  6. * ============================================================================
  7. *
  8. * ============================================================================
  9. *
  10. * ----------------------------------------------------------------------------
  11. *
  12. * ============================================================================
  13. * 定时器
  14. */
  15. class BaseCron extends BaseController {
  16. public function shutdown(){
  17. exit("run ".request()->controller()." success at ".date('Y-m-d H:i:s',TIMESTAMP)."\n");
  18. }
  19. public function initialize(){
  20. parent::initialize();
  21. $config_list = rkcache('config', true);
  22. config($config_list,'ds_config');
  23. set_time_limit(600);
  24. error_reporting(E_ALL & ~E_NOTICE);
  25. register_shutdown_function(array($this,"shutdown"));
  26. }
  27. /**
  28. * 记录日志
  29. * @param unknown $content 日志内容
  30. * @param boolean $if_sql 是否记录SQL
  31. */
  32. protected function log($content, $if_sql = true) {
  33. Log::record('queue\\'.$content);
  34. }
  35. /**
  36. * 更新订单中的佣金比例[多个地方调用,写到父类中]
  37. */
  38. protected function _order_commis_rate_update() {
  39. //实物订单,每次最多处理50W个商品佣金
  40. $_break = false;
  41. $order_model = model('order');
  42. $storebindclass_model = model('storebindclass');
  43. $refundreturn_model = model('refundreturn');
  44. for($i = 0; $i < 5000; $i++) {
  45. if ($_break) {
  46. break;
  47. }
  48. Db::startTrans();
  49. $goods_list = $order_model->getOrdergoodsList(array('commis_rate' => 200), 'rec_id,goods_id,store_id,gc_id', 100, null, '');
  50. if (!empty($goods_list)) {
  51. //$commis_rate_list : store_id => array(gc_id => commis_rate)
  52. $commis_rate_list = $storebindclass_model->getStoreGcidCommisRateList($goods_list);
  53. //更新订单商品佣金值
  54. foreach ($goods_list as $v) {
  55. //如果未查到店铺或分类ID,则佣金置0
  56. if (!isset($commis_rate_list[$v['store_id']][$v['gc_id']])) {
  57. $commis_rate = 0;
  58. } else {
  59. $commis_rate = $commis_rate_list[$v['store_id']][$v['gc_id']];
  60. }
  61. $update = $order_model->editOrdergoods(array('commis_rate' => $commis_rate),array('rec_id' => $v['rec_id']));
  62. if (!$update) {
  63. $this->log('更新实物订单商品佣金值失败'); $_break = true; break;
  64. }
  65. $update = $refundreturn_model->editRefundreturn(array('store_id'=>$v['store_id'],'goods_id'=>$v['goods_id']),array('commis_rate' => $commis_rate));
  66. if (!$update) {
  67. $this->log('更新实物订单退款佣金值失败'); $_break = true; break;
  68. }
  69. }
  70. } else {
  71. break;
  72. }
  73. Db::commit();
  74. }
  75. Db::commit();
  76. //虚拟订单,每次最多处理50W个商品佣金
  77. $_break = false;
  78. $vrorder_model = model('vrorder');
  79. $vrrefund_model = model('vrrefund');
  80. for($i = 0; $i < 5000; $i++) {
  81. if ($_break) {
  82. break;
  83. }
  84. Db::startTrans();
  85. $goods_list = $vrorder_model->getVrorderList(array('commis_rate' => 200),'', 'order_id,store_id,gc_id', '',100);
  86. if (!empty($goods_list)) {
  87. //$commis_rate_list : store_id => array(gc_id => commis_rate)
  88. $commis_rate_list = $storebindclass_model->getStoreGcidCommisRateList($goods_list);
  89. //更新订单商品佣金值
  90. foreach ($goods_list as $v) {
  91. //如果未查到店铺或分类ID,则佣金置0
  92. if (!isset($commis_rate_list[$v['store_id']][$v['gc_id']])) {
  93. $commis_rate = 0;
  94. } else {
  95. $commis_rate = $commis_rate_list[$v['store_id']][$v['gc_id']];
  96. }
  97. $update = $vrorder_model->editVrorder(array('commis_rate' => $commis_rate),array('order_id' => $v['order_id']));
  98. if (!$update) {
  99. $this->log('更新虚拟订单商品佣金值失败'); $_break = true; break;
  100. }
  101. $update = $vrorder_model->editVrorderCode(array('commis_rate' => $commis_rate),array('order_id' => $v['order_id']));
  102. if (!$update) {
  103. $this->log('更新虚拟订单兑换码佣金值失败'); $_break = true; break;
  104. }
  105. $update = $vrrefund_model->editVrrefund(array('order_id' => $v['order_id']),array('commis_rate' => $commis_rate));
  106. if (!$update) {
  107. $this->log('更新虚拟订单商品退款佣金值失败'); $_break = true; break;
  108. }
  109. }
  110. } else {
  111. break;
  112. }
  113. Db::commit();
  114. }
  115. Db::commit();
  116. }
  117. }