繁体   English   中英

Codeigniter的is_unique不适用于多个字段

[英]Codeigniter's is_unique doesn't work with multiple fields

我正在填写注册表,我希望nicke-mail字段是唯一的。 我在控制器中使用表单验证:

  $this->load->library('form_validation'); $this->form_validation->set_rules('nick', '<b>Nazwa użytkownika</b>', 'required|is_unique[users.nick]'); $this->form_validation->set_rules('email', '<b>Adres e-mail</b>', 'required|is_unique[users.mail]'); $this->form_validation->set_rules('password', '<b>Hasło</b>', 'required'); 
    $this->form_validation->set_message('is_unique', '%s jest już w bazie.');

    if ($this->form_validation->run()) {
        $data['submit'] = $this->users_model->CreateUser($this->input->post()); //submits data
        $this->load->view('contribute/emptyPage', $data); //loads view
    } else {
        $data['title'] = 'Załóż konto';
        $this->layout->view('account/create',$data);
    }

当我只填写一个字段时,它起作用。 nickmail 当我填写整个表格时,它的处理没有问题。 我该怎么办?

编辑。

我发现仅当一个或多个字段中只有数字时才会出现问题。

您需要创建自己的自定义验证回调函数

我在这里创建了一个is_unique函数

您可以通过两种方式使用它:

//is_unique[table_name.field_to_check.id_field_name.id_field_value] <-- unique 1 field only
//is_unique[table_name.field_to_check.id_field_name != 'id_field_value' and anotherIdName='theValue'] <-- custom where 

希望对您有用

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM