изменение левого соединения на основное соединение - PullRequest
0 голосов
/ 26 августа 2010

В настоящее время у меня есть некоторый SQL, который должен вернуть 3 строки данных, но возвращает 6 (3 строки повторяются дважды).

Я считаю, что это связано с моим синтаксисом, и я хочу попробовать построить запрос с использованием базовых объединенийВ настоящее время SQL выглядит так:

`function getMultiContentById($id) {
    $query = "SELECT
    FROM `mailers`
    LEFT JOIN `mailer_content` ON `mailers`.`id` = `mailer_content`.`mailer_id`
    LEFT JOIN `mailer_images` ON `mailer_content`.`id` = `mailer_images`.`content_id`
    WHERE `mailers`.`id` = $id"
    $result = runSelectArray($query, __FUNCTION__);
    return $result;
}`

Я хочу использовать что-то вроде этого

`WHERE `mailer_content`.id = `mailers.id`

1 Ответ

1 голос
/ 26 августа 2010

Просто измените ВЛЕВО на ВНУТРЕННИЙ при первом соединении, как в

$query = "SELECT 
    FROM `mailers` 
    INNER JOIN `mailer_content` ON `mailers`.`id` = `mailer_content`.`mailer_id` 
    LEFT JOIN `mailer_images` ON `mailer_content`.`id` = `mailer_images`.`content_id` 
    WHERE `mailers`.`id` = $id" 
    $result = runSelectArray($query, __FUNCTION__); 
    return $result; 

Делись и наслаждайся.

...