OracleDocOrderPackingSummary.php 2.4 KB

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