Сортировка записей в соотношении 1: n (один-ко-многим) - PullRequest
2 голосов
/ 09 августа 2009

У меня есть 2 таблицы:

+-----------+  +------------------------------------+--------------+
+ persons   |  | photos                                            |
+-----------|  +---------------------------------------------------+
+ id | name +  | id | person_id | path              | title        |
+-----------+  +---------------------------------------------------+
+  1 | Tom  +  |  1 |         2 | ~fred/me.png      | Yo, it's Me! |
+  2 | Fred +  |  2 |         2 | ~fred/my_wife.png | I'm Susan    |
+  3 | Jack +  |  3 |         1 | ~tom/my_dog.jpg   | a woof       |
+-----------+  +---------------------------------------------------+

которые имеют в этих отношениях:

Человек имеет много фотографий <-> Фотография принадлежит человеку

Я хотел бы перечислить всех людей с их фотографиями (даже если у кого-то их нет, например, Джек) и упорядочить по названию фотографии.

Какой SQL-запрос (MySQL) я должен написать для этого? Могу ли я использовать объединения в отношениях один ко многим?

PS: В качестве информации я хотел бы иметь возможность построить такой массив с записями:

$persons = Array(
    [0] => Array(
        [id] => 1,
        [name] => 'Tom',
        [Photo] => Array(
            [0] => Array(
                [id] => 3,
                [person_id] => 1,
                [path] => '~tom/my_dog.jpg',
                [title] => 'a woof'             // 1st
            )
        )
    ),
    [1] => Array(
        [id] => 2,
        [name] => 'Fred',
        [Photo] => Array(
            [0] => Array(
                [id] => 2,
                [person_id] => 2,
                [path] => '~fred/my_wife.png',
                [title] => "I'm Susan"          // 2nd
            ),
            [0] => Array(
                [id] => 1,
                [person_id] => 2,
                [path] => '~fred/me.png',
                [title] => "Yo, it's Me!"       // 3rd
            )
        )
    ),
    [2] => Array(
        [id] => 3,
        [name] => 'Jack',
        [Photo] => Array()
    )
)

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

1 Ответ

4 голосов
/ 09 августа 2009
Select *
From persons 
left outer join photos on person.id=photos.person_id
order by photos.title
...