[英]Codeigniter's is_unique doesn't work with multiple fields
我正在填寫注冊表,我希望nick
和e-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);
}
當我只填寫一個字段時,它起作用。 nick
或mail
。 當我填寫整個表格時,它的處理沒有問題。 我該怎么辦?
編輯。
我發現僅當一個或多個字段中只有數字時才會出現問題。
您需要創建自己的自定義驗證回調函數
我在這里創建了一個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.