質問

私は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       |
+-----------+  +---------------------------------------------------+

これはこの関係にあります:

人がhasmany写真<->写真に属します

すべての人に写真を挙げたい(誰かがジャックのように持っていなくても)をリストし、写真のタイトルで注文したいと思います。

これのためにどのようなSQLクエリ(MySQL)を書くべきですか? 1対多くの関係で参加することはできますか?

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()
    )
)

どうもありがとう!

役に立ちましたか?

解決

Select *
From persons 
left outer join photos on person.id=photos.person_id
order by photos.title
ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top