MySQL中的多个左连接

时间:2013-07-29 18:04:53

标签: mysql debugging left-join

我似乎有一些问题让我的多左连接给我正确的结果,它给了我的ID就好了但是我似乎无法得到链接给我结果问题而不是ID。

以下代码。

SELECT 
  a.id as id,
  a.clientid as clientid,
  a.comp_id as compid,
  a.title as title,
  a.firstname as firstname,
  a.lastname as lastname,
  a.countrycode as countrycode,
  a.mobile as mobile,

  a.question1_answer as question1_answer,
  a.question2_answer as question2_answer,
  a.question3_answer as question3_answer,

  a.timestamp as timestamp, 
  b.comp_name as comp_name,
  b.comp_id as comp_id,

  a.question1 as question1,
  a.question2 as question2,
  a.question3 as question3

FROM 
  competition_entries AS a 
LEFT JOIN
  competition as b
ON 
  a.comp_id = b.id
LEFT JOIN
  questions as q
ON 
  a.question1 = q.question_id 
AND
  a.question2 = q.question_id
AND
  a.question3 = q.question_id   
WHERE 
a.comp_id = '$download_id' 

但每次我调用question1 / question2 / question3时 - 显示的唯一结果是与其他表中的ID对应的数字值。

1 个答案:

答案 0 :(得分:2)

您需要三次加入question表,每个ID都有一次:

SELECT a.id as id, a.clientid as clientid, a.comp_id as compid, a.title as title,
       a.firstname as firstname, a.lastname as lastname, a.countrycode as countrycode,
       a.mobile as mobile,
       a.question1_answer as question1_answer,
       a.question2_answer as question2_answer,
       a.question3_answer as question3_answer,
       a.timestamp as timestamp, 
       b.comp_name as comp_name,
       b.comp_id as comp_id,  
       a.question1 as question1id,
       a.question2 as question2id,
       a.question3 as question3id,
       q1.question as question1,
       q2.question as question2,
       q3.question as question3

FROM competition_entries a LEFT JOIN
     competition as b
     ON a.comp_id = b.id LEFT JOIN
     questions as q1
     ON a.question1 = q1.question_id left join
     questions q2
     on a.question2 = q2.question_id left join
     questions q3
     on a.question3 = q3.question_id   
WHERE a.comp_id = '$download_id'