doukai1226 2014-07-24 06:25
浏览 30
已采纳

三个表使用CI加入

I have three tables which I have to join. I'm not a good sql writer. Can please sombody help me to prepare this using joins,

branches

branch_id | branch_name | branch_address
1           name1           address1

branch_services

bs_id | branch_id | service_id
1       1           1
2       1           2
3       1           4

services

service_id | service_name
1               service1
2               service2
3               service3
4               service4

I need to select * from branches table and service_names related to each branch like this

Result

1 | name1 | address1 | service1 service2 service4 |

While i'm searching found something call group_concat.It works. But how to use it with CI???

  • 写回答

4条回答 默认 最新

  • dongxiaowei_1234 2014-07-24 15:51
    关注

    I'm answering my own question so that someone find it usefull,

    $this->db->select("branches.branch_name, branches.branch_address, group_concat(services.service_name)");
    $this->db->from("branches");
    $this->db->join("branch_services", "branches.id = branch_services.branch_id", "left");
    $this->db->join("services", "branch_services.service_id = services.id", "left");
    $query = $this->db->get();
    

    group_concat is the miracle point

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

报告相同问题?

悬赏问题

  • ¥15 unity第一人称射击小游戏,有demo,在原脚本的基础上进行修改以达到要求
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)
  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染