соединить 3 таблицы в mysql codeigniter

У меня есть 3 таблицы в моей базе данных: –

  1. tbl_roles (ROLE_ID, имя_роли);
  2. tbl_users (идентификатор, role_id, имя пользователя, адрес электронной почты, пароль);
  3. tbl_tickets_replies (идентификатор, TICKET_ID, user_id, role_id, комментарии)

role_id, id, id являются первичными ключами соответствующих таблиц. мне нужно :-

  1. имя пользователя из tbl_users.
  2. role_name из tbl_roles.
  3. комментарии от tbl_tickets

где ticket_id из tbl_tickets_replies = $ticket_id появляется как параметр.

Моя модельная функция: –

 function fetch_comments($ticket_id){ $this->db->select('tbl_tickets_replies.comments,tbl_users.username,tbl_roles.role_name'); $this->db->where('tbl_tickets_replies.ticket_id',$ticket_id); $this->db->from('tbl_tickets_replies'); $this->db->join('tbl_users','tbl_users.id = tbl_tickets_replies.user_id'); $this->db->join('tbl_roles','tbl_roles.role_id=tbl_tickets_replies.role_id'); $comments = $this->db->get('tbl_tickets_replies'); return $comments; } 

это показывает ошибку базы данных, т. е. я делаю неправильный запрос. Я хочу спросить, как я могу объединить три таблицы для извлечения данных из трех разных таблиц

Эта ошибка показывает: –

Ошибка базы данных Произошла
Номер ошибки: 1066

Не уникальная таблица / псевдоним: 'tbl_tickets_replies'

SELECT tbl_tickets_replies . comments , tbl_users . username , tbl_roles . role_name FROM ( tbl_tickets_replies , tbl_tickets_replies ) JOIN tbl_users ON tbl_users . id = tbl_tickets_replies . user_id JOIN tbl_roles ON tbl_roles . role_id = tbl_tickets_replies . role_id WHERE tbl_tickets_replies . ticket_id = '6'

Имя файла: C: \ wamp \ www \ local.helpdesk.com \ bonfire \ codeigniter \ database \ DB_driver.php

Номер строки: 330`

Вы дважды ссылаетесь на tbl_tickets_replies . Попробуй это:

 function fetch_comments($ticket_id){ $this->db->select('tbl_tickets_replies.comments, tbl_users.username,tbl_roles.role_name'); $this->db->where('tbl_tickets_replies.ticket_id',$ticket_id); $this->db->join('tbl_users','tbl_users.id = tbl_tickets_replies.user_id'); $this->db->join('tbl_roles','tbl_roles.role_id=tbl_tickets_replies.role_id'); return $this->db->get('tbl_tickets_replies'); } 

Для сложных запросов я предпочитаю использовать простой SQL следующим образом.

 $sql = "SELECT...."; $q = $this->db->query($sql); 

Btw, попробуйте удалить имя таблицы из функции db-> get

 $comments = $this->db->get(); //change this 

Присоединитесь к условию.

 $this->db->select('*'); $this->db->from('articles'); $this->db->join('category', 'category.id = articles.id'); $this->db->where(array('category.id' => 10)); $query = $this->db->get();