ввести присоединение к этому запросу, возможно? - PullRequest
1 голос
/ 04 апреля 2010

Я пытаюсь ввести присоединение к этому запросу:

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`

, добавив

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

после оператора FROM ...

Но когда я представляю его, он завершается с "Неизвестным столбцом 'n.entry_id' в 'предложении'"

Можно ли даже добавить соединение к этому запросу?

Может кто-нибудь помочь, спасибо!

1 Ответ

1 голос
/ 04 апреля 2010

Полагаю, ваша проблема связана с тем, что вы добавляете предложение объединения в конец списка таблиц. Попробуйте

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`

Вы можете ссылаться только в полях предложения ON , которые принадлежат таблицам, которые уже находятся в потоке JOIN.

Надеюсь, это поможет вам, Джером Вагнер

...