多if语句更新申请同一型号,或使用更改记录到另一个模型CakePHP的

问题描述:

我正在从请求数组值和我的第一个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语句 - >如果($ Productsales [“状态”] ==“MoveToShipment”)给我的伟大工程,在第二if语句的情况下 - 如果> ($ Productsales ['status'] =='Returned')其迁移只有一行到我的salereturn表,但我希望请求中的所有记录都迁移到salereturn表。 – ramakrishnan

我不知道真正理解这个问题......

你的意思是这部分代码已经不想要的行为吗?

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

请问您的条件 “$ Productsales [ '状态'] == '返回'” 是什么问题?

可能只有一排你的帖子阵列具有此状态。

+0

有两个if语句,首先如果是在同一个表中单独更新状态,则首先如果未提供,则第二个if语句必须将与以下查询中的product_sales_slno相关的所有行复制到另一个名为sales return的表中。 。$ productsalesre = $ this-> Productsales-> find('all',array('conditions'=> array('Productsales.product_sales_slno'=> $ id))); – ramakrishnan