douxiajiao8445 2015-11-05 23:02
浏览 60
已采纳

使用join语句,但如果table为空

When create a query, I want to use join twice like the following:

$this->db->select('*');
$this->db->from('members');
$this->db->join('members_group', 'members_group.mgid = members.mgid');
$this->db->join('members_profiles','members_profiles.mid = members.mid');
$this->db->where('members.mid=' . $id);
$this->db->get()

The problem in the join statement number 2, If there is no data within the members_profiles table, the query return empty array. but if I remove the join statement number 2, the result will be correct data.

How can I make the query return data whether members_profiles table contains of data that related to a member or not?

  • 写回答

2条回答 默认 最新

  • douluo3256 2015-11-05 23:11
    关注

    Codeigniter allows variant join types to be specified in the third parameter of the join() method.

    Try this:

     $this->db->join('members_profiles','members_profiles.mid = members.mid', 'left');
    

    An ordinary (inner) join suppresses records from the first (left-hand) table that don't match the second (right-hand) table. A left join preserves records on the left that don't match records on the right. It places NULL values in the columns of the resultset that should have come from the missing right-hand table. This does exactly what you want.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 BP神经网络控制倒立摆
  • ¥20 要这个数学建模编程的代码 并且能完整允许出来结果 完整的过程和数据的结果
  • ¥15 html5+css和javascript有人可以帮吗?图片要怎么插入代码里面啊
  • ¥30 Unity接入微信SDK 无法开启摄像头
  • ¥20 有偿 写代码 要用特定的软件anaconda 里的jvpyter 用python3写
  • ¥20 cad图纸,chx-3六轴码垛机器人
  • ¥15 移动摄像头专网需要解vlan
  • ¥20 access多表提取相同字段数据并合并
  • ¥20 基于MSP430f5529的MPU6050驱动,求出欧拉角
  • ¥20 Java-Oj-桌布的计算