DeleteRepetitionSkuItem.php 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. <?php
  2. namespace App\Jobs;
  3. use App\Commodity;
  4. use App\CommodityBarcode;
  5. use App\DeliveryAppointmentDetail;
  6. use App\InventoryAccountMission;
  7. use App\InventoryCompare;
  8. use App\InventoryDailyLog;
  9. use App\OrderCommodity;
  10. use App\OrderCommodityAssign;
  11. use App\OrderPackageCommodities;
  12. use App\ProcessesContent;
  13. use App\Services\LogService;
  14. use App\StationTaskCommodity;
  15. use App\StoreCheckingReceiveItem;
  16. use App\StoreItem;
  17. use Illuminate\Bus\Queueable;
  18. use Illuminate\Contracts\Queue\ShouldQueue;
  19. use Illuminate\Foundation\Bus\Dispatchable;
  20. use Illuminate\Queue\InteractsWithQueue;
  21. use Illuminate\Queue\SerializesModels;
  22. /**
  23. * @Deprecated 重复SKU清理
  24. */
  25. class DeleteRepetitionSkuItem implements ShouldQueue
  26. {
  27. use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
  28. protected $param;
  29. /**
  30. * Create a new job instance.
  31. *
  32. * @return void
  33. */
  34. public function __construct($param)
  35. {
  36. $this->param=$param;
  37. }
  38. /**
  39. * Execute the job.
  40. *
  41. * @return void
  42. */
  43. public function handle()
  44. {
  45. ini_set('max_execution_time', 15);
  46. //关联commodity_id 的表替换商品id
  47. StoreItem::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  48. CommodityBarcode::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  49. InventoryCompare::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  50. InventoryAccountMission::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  51. InventoryDailyLog::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  52. OrderCommodity::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  53. OrderPackageCommodities::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  54. OrderCommodityAssign::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  55. ProcessesContent::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  56. StationTaskCommodity::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  57. StoreCheckingReceiveItem::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  58. DeliveryAppointmentDetail::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  59. foreach ($this->param as $del){
  60. if ($del['id']==$this->param[0]['id']) continue;
  61. Commodity::query()->where('id',$del['id'])->delete();
  62. LogService::log(__METHOD__,"去除重复sku商品",json_encode($del));
  63. }
  64. }
  65. }