【问题标题】:MySQL 2 left joins and no data returnedMySQL 2 left join 没有返回数据
【发布时间】:2013-01-29 15:27:06
【问题描述】:

我使用以下 SQL 来获取一些我想要翻译的键:

SELECT * FROM translate_keys 

LEFT JOIN translations 

ON translate_keys.id = translations.translate_key_id 

LEFT JOIN  languages 

ON languages.id = translations.language_id 

WHERE languages.is_default = 1;

如果一个键的翻译是空的,我不会得到任何结果(语言有内容)!我知道这是因为语言与翻译无关。我能做些什么?我认为左连接就足够了!

【问题讨论】:

标签: mysql left-join


【解决方案1】:

您加入的方向错误。您希望 Language 表成为您的主表。试试这个:

SELECT * 
FROM languages  
  LEFT JOIN translations ON languages.id = translations.language_id 
  LEFT JOIN translate_keys ON translate_keys.id = translations.translate_key_id 
WHERE languages.is_default = 1;

或者,如果您尝试返回所有键并且没有收到任何结果,那是因为您的 WHERE 标准 - 正如@Oswald 正确指出的那样,将其移至您的 JOIN 并且您应该获得记录(显然没有翻译或语言):

SELECT * 
FROM translate_keys 
   LEFT JOIN translations ON translate_keys.id = translations.translate_key_id 
   LEFT JOIN  languages ON languages.id = translations.language_id AND languages.is_default = 1;

【讨论】:

  • 您的 SQL 是正确的,但我需要查看键列表。感谢您的宝贵时间!
【解决方案2】:

问题是WHERE 条件languages.is_default = 1。这消除了左连接添加的所有虚拟记录,因为如果不存在翻译,languages.is_default 就是 NULL

【讨论】:

    猜你喜欢
    • 2021-02-09
    • 1970-01-01
    • 2013-11-28
    • 2020-05-10
    • 2019-04-23
    • 1970-01-01
    • 1970-01-01
    • 2020-08-02
    • 1970-01-01
    相关资源
    最近更新 更多