1

我正在编写的模块(商店产品模块)有问题。

当我运行一次表单验证时,一切都很好。但是,当我edit()再次运行产品并运行验证时(这是我所期望的),但它返回一个错误,指出 slug 必须是唯一的。

如何更改编辑模式的验证规则以忽略检查现有行/字段?

下面是我的控制器类的一个子集:

public function create() {
    //this works fine
    $this->form_validation->set_rules('slug', 'Slug',
     'trim|required|is_unique[shop_products.slug]');    

    if ($this->form_validation->run()) { }
}

//when this runs the validation for slug returns saying not unique
// do i need a different validation rule ??

public function edit($id = 0) {
    $this->data = $this->products_m->get($id);

    $this->form_validation->set_rules('slug', 'Slug',
     'trim|required|is_unique[shop_products.slug]');    

    if ($this->form_validation->run()) { }
}
4

1 回答 1

4

这是因为您已将其保存slug在数据库中并在对其进行编辑时。它返回一个错误,因为它引用了它自己。您可以尝试call_back function在更新新值时创建一个,然后该函数连接到模型并运行查询来检查新值。你可以尝试这样的事情:


更新
您永远不应该更新ID ,特别是如果primary key - auto increment您可以使用它来查找要更新的特定slug,您可以检查slug唯一性但不能检查id if its the primary key

public function check_slug()
{
    $id = $this->input->post('id');
    $data = array('id' => $id);
    if($this->model->check_slug($data))     
        return false;
    else
        return true;
    // end if
} // end function

public function update_slug_valiation()
{
    $id = $this->input->post('id');
    $slug = $this->input-->post('slug');
    $this->form_validation->set_rules('slug', 'Slug', 'callback_check_slug');

    if($this->form_validation->run() == TRUE)
    {
        $data = array('slug' => $slug);
        if($this->model->update_slug($data))
        {
            echo "<script> alert('Slug Updated!'); </script>";
        }
        else
        {
            echo "<script> alert('Updating Failed!'); </script>";
        }
        //end if
    }
    else
    {
        echo "<script> alert('Slug is already taken'); </script>";
    }
    // end if
} // end function
于 2013-06-19T03:26:50.417 回答