【问题标题】:MySQL Join Return NullMySQL Join 返回 Null
【发布时间】:2012-12-04 09:15:55
【问题描述】:

我有两张桌子

Table_1
id|subject_code|subject_id
 1|Test1       |1
 2|Test2       |2
 3|Test3       |3

Table2
id|subject_id|grade|status
 1|1         |5.00 |Fail
 2|3         |2.25 |Pass

现在,我想创建一个返回以下内容的查询,

Table3
subject_code|grade|status
Test1       |5.00 |Fail
Test2       |NULL |NULL
Test3       |2.25 |Pass

我已经阅读了关于结合 left join 和 union all 的信息,但我不知道如何做到这一点。 提前致谢。

【问题讨论】:

    标签: mysql join left-join union-all


    【解决方案1】:

    尝试左连接,如下所示::

    Select 
    DISTINCT(table1.subject_code), 
    grade, 
    status
    
    from table1 
    LEFT join table2 on (table1.subject_id=table2.subject_id)
    

    【讨论】:

    • 这会返回相同的行。
    【解决方案2】:
    SELECT subject_code, grade, status 
    FROM Table_1 t1 
    LEFT JOIN Table2 t2 ON t1.subject_id = t2.subject_id;
    

    【讨论】:

    • 这会返回相同的行。
    【解决方案3】:

    我想一个简单的 LEFT JOIN 就可以解决问题:

    SELECT Table_1.subject_code, Table2.grade, Table2.status FROM Table_1 LEFT JOIN Table2 ON Table2.subject_id = Table_1.subject_id;

    【讨论】:

    • 这将返回相同的行。
    猜你喜欢
    • 2014-02-14
    • 2013-04-26
    • 1970-01-01
    • 1970-01-01
    • 2019-03-25
    • 1970-01-01
    • 1970-01-01
    • 2021-02-09
    • 1970-01-01
    相关资源
    最近更新 更多