【发布时间】:2012-07-16 12:10:43
【问题描述】:
我的数据库中有 3 个表:-
- tbl_roles(role_id,role_name);
- tbl_users(id,role_id,username,email,password);
- tbl_tickets_replies(id,ticket_id,user_id,role_id,cmets)
role_id, id, id是对应表的主键。
我需要:-
- 来自 tbl_users 的用户名。
- 来自 tbl_roles 的角色名称。
- 来自 tbl_tickets 的 cmets
其中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'
选择
tbl_tickets_replies.comments,tbl_users.username,tbl_roles.role_nameFROM (tbl_tickets_replies,tbl_tickets_replies) 加入tbl_users开启tbl_users.id=tbl_tickets_replies.user_id加入tbl_roles开启tbl_roles.role_id=tbl_tickets_replies.role_id在哪里tbl_tickets_replies.ticket_id= '6'文件名:C:\wamp\www\local.helpdesk.com\bonfire\codeigniter\database\DB_driver.php
行号:330`
【问题讨论】:
-
删除
from子句或从 $this->db->get() 中删除表。你不需要两者。你得到什么错误? -
您没有删除
$this->db->from或删除了:$this->db->get(); -
感谢 yan 通过删除 $this->db->from() 解决了
标签: php mysql codeigniter join