我有以下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
这是我尝试显示结果的底部表格。
答案 0 :(得分:1)
答案 1 :(得分: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
这适用于任何数据库。
答案 2 :(得分: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