2010-04-04 8 views
1

Je suis en train d'introduire une jointure à cette requête:introduire une jointure à cette requête, possible?

SELECT `n`.*, round((`n`.`rgt` - `n`.`lft` - 1)/2, 0) AS childs, 
count(*) - 1 + (`n`.`lft` > 1) + 1 AS level, 
((min(`p`.`rgt`) - `n`.`rgt` - (`n`.`lft` > 1))/2) > 0 AS lower, 
(((`n`.`lft` - max(`p`.`lft`) > 1))) AS upper 
FROM `exp_node_tree_6` `n`, `exp_node_tree_6` `p`, `exp_node_tree_6` 
WHERE `n`.`lft` 
BETWEEN `p`.`lft` 
AND `p`.`rgt` 
AND (`p`.`node_id` != `n`.`node_id` OR `n`.`lft` = 1) 
GROUP BY `n`.`node_id` 
ORDER BY `n`.`lft` 

en ajoutant

LEFT JOIN `exp_channel_titles` 
ON (`n`.`entry_id`=`exp_channel_titles`.`entry_id`) 

après la FROM ...

Mais quand je présente, il échoue avec "Colonne inconnue 'n.entry_id' dans 'on clause'"

Est-il même possible d'ajouter une jointure à cette requête?

Quelqu'un peut-il aider, merci!

Répondre

1

Je suppose que votre problème vient du fait que vous ajoutez la clause join à la fin de la liste des tables. Essayez

SELECT `n`.*, round((`n`.`rgt` - `n`.`lft` - 1)/2, 0) AS childs, 
count(*) - 1 + (`n`.`lft` > 1) + 1 AS level, 
((min(`p`.`rgt`) - `n`.`rgt` - (`n`.`lft` > 1))/2) > 0 AS lower, 
(((`n`.`lft` - max(`p`.`lft`) > 1))) AS upper 
FROM `exp_node_tree_6` `n` 
    LEFT JOIN `exp_channel_titles` 
    ON (`n`.`entry_id`=`exp_channel_titles`.`entry_id`), 

    `exp_node_tree_6` `p`, 
    `exp_node_tree_6` 
WHERE `n`.`lft` 
BETWEEN `p`.`lft` 
AND `p`.`rgt` 
AND (`p`.`node_id` != `n`.`node_id` OR `n`.`lft` = 1) 
GROUP BY `n`.`node_id` 
ORDER BY `n`.`lft` 

Vous ne pouvez faire référence dans un SUR champs clause qui appartiennent aux tables qui sont déjà dans le flux JOIN.

J'espère que cela vous aidera, Jérôme Wagner

+0

Merci beaucoup !!!!! –

+0

pouvez-vous accepter la réponse si cela vous convient? Merci. Jerome –

+0

Il ne me laisserait pas parce que vous étiez si rapide ... l'ai fait maintenant :) –

Questions connexes