0

次のSQLテーブル構造があります(テーブル名「my_table」):

**ID - USER_ID - FIELD_ID - VALUE**

1 - 1 - 1 - letter a

2 - 1 - 2 - letter b

3 - 1 - 3 - letter c

4 - 2 - 1 - letter a

5 - 2 - 2 - letter b

次に、次のように結果を html テーブルに表示したいと思います。

**USER_ID - FIELD_ID1->value - FIELD_ID2->value - FIELD_ID3->value**

1 - letter a - letter b - letter c

2 - letter a - letter b

テイカーはいますか?? ありがとう :)

編集:

ここにフィドルがあります: http://sqlfiddle.com/#!2/bd980/5

結果を表示しようとしている一番下のテーブルです。

4

3 に答える 3

1

GROUP_CONCAT を試す

Select user_id, group_concat(value,' - ') from t
Group By user_id

デモ

于 2012-12-06T23:04:07.877 に答える
0

手動ピボットでこれを行うことができます:

select user_id,
       max(case when key = 1 then value end) as Key1,
       max(case when key = 2 then value end) as Key2,
       max(case when key = 3 then value end) as Key3
from t
group by user_id

これは、どのデータベースでも機能するはずです。

于 2012-12-06T23:05:14.867 に答える
0

これはうまくいくはずです:

SELECT t.user_id,
       MAX(IF(t.field_id = 1, t.value, NULL)) AS key1,
       MAX(IF(t.field_id = 2, t.value, NULL)) AS key2,
       MAX(IF(t.field_id = 3, t.value, NULL)) AS key3
FROM my_table t
GROUP BY t.user_id
于 2012-12-07T00:40:51.327 に答える