Codeigniter的is_unique不适用于多个字段

时间:2012-07-04 12:16:20

标签: php codeigniter

我正在制作注册表单,我希望字段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。当我填写整个表单时,它会毫无问题地处理。我能做什么?

修改。

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

2 个答案:

答案 0 :(得分:1)

您需要创建自己的custom validation callback function

答案 1 :(得分:0)

我创建了is_unique function here

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

//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 

希望它对你有用