0

我正在尝试使用此代码更新对象:该列co_nbre将更新为 0 !!!我想你会帮助我解决这个问题,并且非常感谢。

public function update($model) {
        $data = get_object_vars($model);
        $id = (int) $model->id;
        $this->tableGateway->update($data, array('id' => $id));
    }

这就是我在控制器中使用它的方式:

 if ($form->isValid()) {
                    $data = $form->getData();
                    $addi_info = new Addiinfo();
                    $addi_info->exchangeArray($data);
                    $addi_info->co_nbre = $request->getPost("co_nbre");  
                    $addi_info->user_pin = $this->layout()->pin;  
                    $addi_info->co_latitude = $request->getPost("latitude");
                    $addi_info->co_longitude = $request->getPost("longitude");
                    $addi_info->co_adresse = $request->getPost("adresse");
                    print_r($addi_info);die;
                    $checkuser=$this->getAddiinfoTable()->getAddiInfoByUserPin($user_pin);
                   if($checkuser[user_pin]==$user_pin){
                       $this->getAddiinfoTable()->update($addi_info);
4

1 回答 1

0

我认为您应该创建一个从模型本身返回关联数组的函数。

可能是“Addiinfo”类中的某些属性受到保护/私有,因此您需要从其中获取模型的所有属性值。

这个应该在你的“Addiinfo”类中,

public function getArrayData()
{
    return get_object_vars($this);
}

然后在更新函数中调用它

public function update($model) {
        $data = $model->getArrayData();
        $id = (int) $model->id;
        $this->tableGateway->update($data, array('id' => $id));
    }
于 2017-08-09T22:04:33.947 回答