У меня есть что-то вроде базы данных для голосования, поэтому я сделал свою базу данных вот так
Vote_table:
user_id
product_id
vote
primary key is both user_id & product_id
так что никто не может проголосовать за товар дважды, а это моя модель:
public function add_vote_records($product_id, $user_id)
{
$this->db->set('product_id', $product_id);
$this->db->set('members_id', $user_id);
$query = $this->db->insert('product_votes');
if ($query->num_rows() == 0)
return FALSE;
return $query->result_array();
}
и это мой контроллер:
if ($this->products_model->add_vote_records($product_id, $user_id)) {
$this->product($product_id);
} else {
$this->session->set_flashdata('flash_message', 'Sorry you already voted.');
$this->product($product_id);
}
но это дает мне эту ошибку, когда я пытаюсь проголосовать, когда я уже проголосовал:
Дублирующая запись ‘8-2’ для ключа ‘ПЕРВИЧНЫЙ’
И это то, чего я действительно хочу, но я хочу дать пользователю другое сообщение вместо моего сообщения об ошибке.
Задача ещё не решена.
Других решений пока нет …