2017-02-01 21 views
0

Ich bekomme Array-Wert von der Anfrage und meine erste if-Anweisung funktioniert gut, im Fall der zweiten if-Anweisung seine Migration nur eine Reihe zu meinem Tisch, aber ich möchte, dass der gesamte Datensatz in der Anfrage auf den Tisch für den Verkauf rückgängig gemacht wird.Mehrere if-Anweisung zu aktualisieren das gleiche Feld Modell oder die Datensätze zu einem anderen Modell mit Cakephp

if ($this->request->is('post')) { 

    $Productsalesrec = !empty($this->request->data['Productsales']) ? $this->request->data['Productsales'] : ""; 

    if (!empty($Productsalesrec)) { 
     foreach ($Productsalesrec as $Productsales) { 

      if ($Productsales['status'] == 'MoveToShipment') { 

       $this->Productsales->id = $Productsales['id']; 
       $this->request->data['Productsales']['status'] = $Productsales['status']; 
       $this->Productsales->save($this->request->data); 
      } 

      if ($Productsales['status'] == 'Returned') { 

       $productsalesretArr = array(); 
       $productsalesre = $this->Productsales->find('all', array('conditions' => array('Productsales.product_sales_slno' => $id))); 

       $this->request->data['Salesreturn']['sales_order_date'] = $productsalesre['Productsales']['sales_order_date']; 
       $this->request->data['Salesreturn']['product_sale_id'] = $productsalesre['Productsales']['id']; 
       $this->request->data['Salesreturn']['sales_date'] = $productsalesre['Productsales']['expected_delivery_date']; 
       $this->request->data['Salesreturn']['product_sales_slno'] = $productsalesre['Productsales']['product_sales_slno']; 
       $this->request->data['Salesreturn']['price_per_unit_order'] = $productsalesre['Productsales']['sales_price_per_unit_order']; 
       $this->request->data['Salesreturn']['total_amount'] = $productsalesre['Productsales']['sales_price_per_unit_order'] * $Productsales['tot_unit']; 
       $this->request->data['Salesreturn']['total_unit'] = $Productsales['tot_unit']; 
       $this->request->data['Salesreturn']['product_id'] = $Productsales['product_id']; 
       $this->request->data['Salesreturn']['amount_returned'] = 0; 
       $this->request->data['Salesreturn']['status'] = 'Returned'; 
       $this->request->data['Salesreturn']['payment_method'] = 'Cash on Delivery'; 
       $this->request->data['Salesreturn']['created_date'] = date('Y-m-d H:i:s'); 
       $this->request->data['Salesreturn']['created_by'] = $this->Auth->user('id'); 

       $this->Salesreturn->save($this->request->data['Salesreturn']); 

       if ($Productsales['total_unit'] == $Productsales['tot_unit']) { 
        $this->Productsales->delete($Productsales['id']); 
       } elseif ($Productsales['total_unit'] >= $Productsales['tot_unit']) { 
        $this->Productsales->id = $Productsales['id']; 
        $this->request->data['Productsales']['total_unit'] = $Productsales['total_unit'] - $Productsales['tot_unit']; 
        $this->Productsales->save($this->request->data); 
       } 

       $prodtype = $this->Producttype->find('first', array('conditions' => array('Producttype.id' => $productsalesre['Productsales']['product_type_id']))); 
       $this->Producttype->id = $prodtype['Producttype']['id']; 

       $prodquantity = $prodtype['Producttype']['quantity'] + ($Productsales['total_unit'] - $Productsales['tot_unit']); 
       $prodtotstck = $prodtype['Producttype']['total_unit_stock'] + ($Productsales['total_unit'] - $Productsales['tot_unit']); 

       $this->Producttype->saveField('total_unit_stock', $prodtotstck); 
       $this->Producttype->saveField('quantity', $prodquantity); 
      } 
     } 
     $this->redirect(array('action' => 'index')); 
    } 
} 
+0

Ich bekomme Array-Wert von der Anfrage und meine erste if-Anweisung -> if ($ Productsales ['status'] == 'MoveToShipmentment') funktioniert super, im Falle der zweiten if-Anweisung -> if ($ Productsales ['status'] == 'Returned') es migriert nur eine Zeile in meine Tabelle zurück, aber ich möchte, dass der gesamte Datensatz in der Anfrage in die Tabelle zurückkehrt. – ramakrishnan

Antwort

0

Ich bin nicht sicher, wirklich das Problem zu verstehen ...

Wollen Sie diesen Teil des Codes hat nicht das gewünschte Verhalten?

if($Productsales['status'] == 'Returned') { 
    $this->request->data['Salesreturn']['sales_order_date']=$productsalesre['Productsales']['sales_order_date'];  
    ... 
    $this->Salesreturn->save($this->request->data['Salesreturn']); 
} 

Hat Ihr Zustand "$ UmsätzeNachArtikeln [ 'Status'] == 'zurückgegeben'" ist das Problem?

möglicherweise nur eine Zeile Ihres Post-Arrays diesen Status hat.

+0

gibt es zwei if-Anweisung, zuerst, wenn der Status allein in der gleichen Tabelle aktualisiert wird, zuerst, wenn nicht gedient wird, als die zweite if-Anweisung muss alle Zeilen mit der Product_sales_slno aus der folgenden Abfrage in eine andere Tabelle mit dem Namen Umsatzrückgabe kopiert werden. . $ productsalesre = $ this-> Productsales-> find ('alle', array ('bedingungen' => array ('Productsales.product_sales_slno' => $ id))); – ramakrishnan

Verwandte Themen