У меня есть 3 таблицы в моей базе данных: –
role_id, id, id
являются первичными ключами соответствующих таблиц. мне нужно :-
где 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
) JOINtbl_users
ONtbl_users
.id
=tbl_tickets_replies
.user_id
JOINtbl_roles
ONtbl_roles
.role_id
=tbl_tickets_replies
.role_id
WHEREtbl_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();