我想连接表,其中 table1
和 table2
是公共(public)字段,并且 table2
包含字段 record_id
whos描述位于 table3
字段 record_desc
查询什么?
table1
和 table3
之间没有直接关系
我尝试了这样的方法,但行不通。
$this->db->select('*');
$this->db->from('table1');
$this->db->join('table2', 'table1.id = table2.id');
$this->db->join('table3', 'table2.record_id= table3.record_desc');
$query = $this->db->get();
最佳答案
我认为这行是不正确的
$this->db->join('table3', 'table2.record_id= table3.record_desc');
因为table3.record_desc
不是表2到表3的外键,对吧?
查询可能是这样的
$this->db->join('table3', 'table2.record_id= table3.record_id');
因为你必须有一个外键来匹配表 2 和表 3 中的记录。
当您选择结果时,如果您这样做
$this->db->select('*');
如果每个表中的列名称相同,则结果中只会出现一列。
所以尝试只获取你想要的列
$this->db->select('table1.id,table2.record_id,table3.record_desc');
希望这有帮助。
关于mysql - 没有直接关系的 Sql 表连接 [ codeigniter ],我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28893383/