【问题标题】:SQL Query join with more than one table with relation one-to-manySQL Query连接多个表,关系为一对多
【发布时间】:2017-09-04 04:20:09
【问题描述】:

我有以下表格:

tbl_destination

id_destination INT PRIMARY
destination_name VARCHAR(200)

tbl_destination_category

id_destination_category INT PRIMARY
id_destination INT
id_category INT

tbl_destination_activity

id_destination_activity INT PRIMARY
id_destination INT
id_activity INT

tbl_category

id_category INT PRIMARY
category_name VARCHAR(200)

tbl_activity

id_activity INT PRIMARY
activity_name VARCHAR(200)

我想选择目标数据,包含类别和活动 WHERE:

  • 一个目的地可以有多个类别(tbl_destination 一对多 tbl_destination_category)
  • 一个目的地可以有多个活动(tbl_destination 一对多 tbl_destination_activity)

我的预期输出示例:

----------------------------------- -------------------------------------------------- --------------------
目的地名称 类别 活动
-------------------------------------------------- -------------------------------------------------- -----------------
珠穆朗玛峰 山,自然 徒步旅行、徒步旅行、露营



这可以在一个查询中完成吗?或者什么是最有效的查询?

【问题讨论】:

    标签: mysql join optimization


    【解决方案1】:

    每个关系会有不止一行,但你的 SQL 在这里:

     select td.destination_name,  tc.category_name, ta.activity_name
     from tbl_destination td
     inner join tbl_destination_category tdc on tdc.id_destination = td.id_destination 
        iiner join tbl_destination_activity tda on tda.id_destination = td.id_destination 
        iiner join tbl_category tc on tc.id_category = tdc.id_category 
        inner join tbl_activity ta on ta.id_activity  = tda.id_activity 
    

    【讨论】:

    • 使用 group by 和 group_concat 来获得 OP 要求的输出。
    猜你喜欢
    • 1970-01-01
    • 2015-03-22
    • 2023-03-04
    • 1970-01-01
    • 2015-09-08
    • 2019-08-22
    • 2012-06-15
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多