duan0417 2018-04-11 02:59
浏览 80
已采纳

LEFT JOIN CODEIGNITER中的错误“不唯一的表/别名”

I've a got a error says Not unique table/alias: 'pcdom_missionaries'

here's my sample code in model

public function samplemethodname()
    {
        $this->db->select('companionship_id, missionary_one_id, missionary_two_id, missionary_three_id, pcdom_companionship.zone_id AS pczone_id, pcdom_companionship.district_id AS pcdistrict_id,
            pcdom_companionship.area_id AS pcarea_id, assignment, zone_name, pcdom_zone.zone_id AS pz_zone_id, district_name, pcdom_district.district_id AS pd_district_id, area_name, pcdom_area.area_id AS pa_area_id, missionary_id, missionaries_name')
                ->from('pcdom_companionship')
                ->join('pcdom_missionaries','pcdom_missionaries.missionary_id = pcdom_companionship.missionary_one_id','left')
                ->join('pcdom_missionaries','pcdom_missionaries.missionary_id = pcdom_companionship.missionary_two_id','left')
                ->join('pcdom_missionaries','pcdom_missionaries.missionary_id = pcdom_companionship.missionary_three_id','left')
                ->join('pcdom_zone','pcdom_zone.zone_id = pcdom_companionship.zone_id','left')
                ->join('pcdom_district','pcdom_district.district_id = pcdom_companionship.district_id','left')
                ->join('pcdom_area','pcdom_area.area_id = pcdom_companionship.area_id','left');
                $sql = $this->db->get();
                if($sql && $sql->num_rows() > 0 )
                    return $sql->result();
                else
                    return;
    }

An error appears in the image

Not unique table/alias: 'pcdom_missionaries'

Can Anyone had the ideas? thanks in advance

  • 写回答

1条回答 默认 最新

  • doupacan2098 2018-04-11 03:10
    关注

    Since you are doing self joins on pcdom_missionaries you need to alias pcdom_missionaries table in each separate joins to make it look unique to SQL so it can use it in joins without confusion

    ->join('pcdom_missionaries as pcdom_m1','pcdom_m1.missionary_id = pcdom_companionship.missionary_one_id','left')
    ->join('pcdom_missionaries as pcdom_m2','pcdom_m2.missionary_id = pcdom_companionship.missionary_two_id','left')
    ->join('pcdom_missionaries as pcdom_m3','pcdom_m3.missionary_id = pcdom_companionship.missionary_three_id','left')
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python
  • ¥15 要给毕业设计添加扫码登录的功能!!有偿
  • ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘