2017-02-01 20 views
0

Я получаю значение массива из запроса, и мое первое утверждение if отлично работает для меня, в случае второго оператора if его только для миграции одна строка в моей таблице salereturn, но я хочу, чтобы все записи в запросе были перенесены в таблицу salereturn.Несколько операторов if, чтобы обновить зарегистрированную модель или изменить записи на другую модель, используя 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

Я получаю значение массива от запроса и моего первого оператора if -> if ($ Productsales ['status'] == 'MoveToShipment') отлично работает для меня, в случае второго оператора if -> if ($ Productsales ['status'] == 'Returned') его перенос только одной строки в мою таблицу salereturn, но я хочу, чтобы вся запись в запросе была перенесена в таблицу salereturn. – ramakrishnan

ответ

0

Я не уверен, что по-настоящему понять проблему ...

ли вы имеете в виду эту часть кода не имеет разыскиваемого поведение?

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

Выполняется ли ваше условие «$ Productsales ['status'] == 'Returned' '?

может быть только одна строка вашего массива сообщений имеет этот статус.

+0

есть два оператора if, сначала если необходимо обновить статус в одной таблице, сначала, если не подано, чем второй оператор if должен скопировать все строки, связанные с product_sales_slno, из приведенного ниже запроса в другую таблицу, называемую возвратом продаж. $ productsalesre = $ this-> Productales-> find ('all', array ('conditions' => array ('Productsales.product_sales_slno' => $ id))); – ramakrishnan

 Смежные вопросы

  • Нет связанных вопросов^_^