DeleteRepetitionSkuItem.php 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  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. class DeleteRepetitionSkuItem implements ShouldQueue
  23. {
  24. use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
  25. protected $param;
  26. /**
  27. * Create a new job instance.
  28. *
  29. * @return void
  30. */
  31. public function __construct($param)
  32. {
  33. $this->param=$param;
  34. }
  35. /**
  36. * Execute the job.
  37. *
  38. * @return void
  39. */
  40. public function handle()
  41. {
  42. ini_set('max_execution_time', 15);
  43. //关联commodity_id 的表替换商品id
  44. StoreItem::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  45. CommodityBarcode::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  46. InventoryCompare::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  47. InventoryAccountMission::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  48. InventoryDailyLog::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  49. OrderCommodity::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  50. OrderPackageCommodities::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  51. OrderCommodityAssign::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  52. ProcessesContent::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  53. StationTaskCommodity::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  54. StoreCheckingReceiveItem::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  55. DeliveryAppointmentDetail::query()->whereIn('commodity_id',data_get($this->param,'*.id'))->update(['commodity_id'=>$this->param[0]['id']]);
  56. foreach ($this->param as $del){
  57. if ($del['id']==$this->param[0]['id']) continue;
  58. Commodity::query()->where('id',$del['id'])->delete();
  59. LogService::log(__METHOD__,"去除重复sku商品",json_encode($del));
  60. }
  61. }
  62. }