Как использовать LEFT JOIN в этом запросе - PullRequest
0 голосов
/ 16 февраля 2011

У меня есть следующий запрос

SELECT
    interview_content.title `title`,
    gallery_images.img_path img
FROM
    `interview`,
    `interview_content`,
    `gallery`,
    `gallery_images`
WHERE
    `gallery_images`.`id_parrent` = `gallery`.`id`
AND
    `gallery`.`id` =  `interview`.`gallery_id`
AND
    `gallery_images`.`default` = '1'
AND
    `interview`.`id` = `interview_content`.`id_parrent`
AND
    interview_content.id_lang = '2'
ORDER BY
    interview.date DESC

Мне нужно использовать LEFT JOIN для таблиц gallery, gallery_images (чтобы получить interview.title, даже если нет галереи или изображения по умолчанию)

Большое спасибо

UPDATE


Проблема во втором левом соединении. Я не могу заставить их работать вместе правильно. Когда я пытаюсь

SELECT
    interview_content.title `title`,
    gi.img_path img
FROM
    `interview`,
    `interview_content`
LEFT JOIN `gallery` as g ON g.`id` = `interview`.`gallery_id` 
LEFT JOIN `gallery_images` as gi ON gi.id_parrent = g.`id`
WHERE
    `interview`.`id` = `interview_content`.`id_parrent`
AND
    interview_content.id_lang = '2'
ORDER BY
    interview.date DESC

it returns //Unknown column 'interview.gallery_id' in 'on clause'

Ответы [ 3 ]

3 голосов
/ 16 февраля 2011

Вы знаете, что вам нужно делать. Google твой друг?

http://en.wikipedia.org/wiki/Join_%28SQL%29#Left_outer_join

1 голос
/ 17 февраля 2011

Не смешивайте соединения в стиле ANSI-89 и ANSI-92.

Я нашел такой же вопрос в SO, здесь .

Так что мой запрос должен выглядеть так

SELECT
    ic.title `title`,
    gi.img_path img
FROM
    `interview` i
JOIN interview_content ic  on ic.id_parrent =  i.id AND ic.id_lang = '2'
LEFT JOIN `gallery` as g ON g.`id` = i.`gallery_id` 
LEFT JOIN `gallery_images` as gi ON gi.id_parrent = g.`id`
AND gi.`default` = '1'
WHERE
    i.`id` = ic.`id_parrent`
OPRDER BY
    `i`.`date` DESC
1 голос
/ 16 февраля 2011

Попробуйте это:

SELECT
    interview_content.title `title`,
    gallery_images.img_path img
FROM
    `interview`,
    `interview_content`,
LEFT JOIN `gallery` ON (`interview`.`gallery_id` = `gallery`.`id` AND `gallery_images`.`default` = '1'), 
LEFT JOIN `gallery_images` ON `gallery`.`id` = `gallery_images`.`id_parrent`
WHERE
    `interview`.`id` = `interview_content`.`id_parrent`
AND
    interview_content.id_lang = '2'
ORDER BY
    interview.date DESC;
...