OracleIdxAsrsReceive.php 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. <?php
  2. namespace App;
  3. use Carbon\Carbon;
  4. use Illuminate\Database\Eloquent\Model;
  5. use Illuminate\Support\Facades\DB;
  6. use App\Traits\ModelLogChanging;
  7. class OracleIdxAsrsReceive extends Model
  8. {
  9. use ModelLogChanging;
  10. protected $connection="oracle";
  11. protected $primaryKey="GROUPTASKID";
  12. protected $table = 'idx_asrs_receive';
  13. protected $fillable = ['grouptaskid','grouptasksequence','userdefine1','userdefine2','addwho','addtime'];
  14. public $timestamps=false;
  15. public function getIncrementing(){ return false;}
  16. static public function saveOrUpdateWeightByBatch($batchNumber,$weight){
  17. $numbersesOfBatch=OracleDOCWaveDetails::select('picktotraceid as logistic_number','act_allocation_details.orderno')->where('doc_wave_details.waveno',$batchNumber)
  18. ->leftJoin('act_allocation_details','doc_wave_details.orderno','act_allocation_details.orderno')->get();
  19. $numbersesOfBatch=$numbersesOfBatch->unique('logistic_number');
  20. $logisticNumbers=$numbersesOfBatch->map(function($numbers){return $numbers['logistic_number'];});
  21. $logisticNumbers_toInsert=[];
  22. $idxAsrsReceives=OracleIdxAsrsReceive::whereIn('userdefine1',$logisticNumbers)->get();
  23. if($idxAsrsReceives->count()<$numbersesOfBatch->count()){
  24. foreach($numbersesOfBatch as $numbers){//跳过idx_asrs_receive已有快递单号
  25. foreach($idxAsrsReceives as $existingAsrsReceive){
  26. if($existingAsrsReceive['userdefine1']==$numbers['logistic_number']){
  27. continue 2;
  28. }
  29. }
  30. $logisticNumbers_toInsert[]=$numbers['logistic_number'];
  31. }
  32. $inserts='';
  33. $values=[];
  34. foreach($logisticNumbers_toInsert as $logisticNumber){
  35. $inserts .= " into idx_asrs_receive (grouptaskid,grouptasksequence,userdefine1,userdefine2,addwho,addtime)values(?,?,?,?,?,?) ";
  36. $values[] = $logisticNumber??'';
  37. $values[] = 1;
  38. $values[] = $logisticNumber??'';
  39. $values[] = $weight;
  40. $values[] = 'WAS';
  41. $values[] = Carbon::now();
  42. }
  43. DB::connection('oracle')->insert("insert all {$inserts} select * from dual",$values);
  44. }
  45. OracleIdxAsrsReceive::whereIn('userdefine1',$logisticNumbers)->update(['userdefine2'=>$weight]);
  46. }
  47. }