多个if语句用于更新已归档的相同模型或使用Cakephp将记录更改为另一个模型

时间:2017-02-01 20:31:30

标签: cakephp cakephp-2.3

我从请求获取数组值,我的第一个if语句对我很有用,在第二个if语句的情况下,它只将一行迁移到我的salereturn表,但我希望请求中的所有记录都迁移到salereturn表。

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'));
    }
}

1 个答案:

答案 0 :(得分: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'] =='已退回' "问题是什么?

可能只有你的帖子数组的一行具有此状态。

相关问题