1

次のようなテーブルがあります。

id   person_id  total amount    date_time
1    101        2000            2001-12-10
2    102        1000            2001-12-10
3    102        3000            2001-12-10
4    102        2000            2001-12-10
5    103        1000            2001-12-11
6    101        1000            2001-12-11
7    102        3000            2001-12-11
8    102        4000            2001-12-11
9    102        4000            2001-12-11

日付 2001-12-11 の出力を以下のようにしたい

person_101   person_102   person_103
1000         11000         1000

関数を使用してみましたが、 and句SUM()にこだわっています。これを解決するにはどうすればよいですか?WHEREJOIN

4

2 に答える 2

2
SELECT
  SUM(CASE WHEN person_id = 101 THEN total_amount ELSE 0 END) as person_101,
  SUM(CASE WHEN person_id = 102 THEN total_amount ELSE 0 END) as person_102,
  SUM(CASE WHEN person_id = 103 THEN total_amount ELSE 0 END) as person_103
FROM
  my_table
WHERE
  date_time ='2001-12-11'
于 2013-06-05T07:07:07.277 に答える
0

データをピボットする必要があります。残念ながら、これは では動的ではありませんmysql。これを試してください:

SELECT
    SUM(IF(person_id = 101,total_amount,0)) as person_101,
    SUM(IF(person_id = 102,total_amount,0)) as person_102,
    SUM(IF(person_id = 103,total_amount,0)) as person_103
FROM
    my_table
WHERE
    date_time = '2001-12-11'

また、このピボットを日付で分割することもできます。フィールド リストに入れ、それでグループ化するだけです。

SELECT
    date_time,
    SUM(IF(person_id = 101,total_amount,0)) as person_101,
    SUM(IF(person_id = 102,total_amount,0)) as person_102,
    SUM(IF(person_id = 103,total_amount,0)) as person_103
FROM
    my_table
GROUP BY
    date_time
于 2013-06-05T07:04:54.283 に答える