0
我有2代表这样MySql的选择查询
Table 1
Id f1 f2
1 ABC red,green
2 DEF blue,yellow
Table 2
id color value
1 red r
2 green g
3 blue b
4 yellow y
我怎样才能得到这样的提前
我有2代表这样MySql的选择查询
Table 1
Id f1 f2
1 ABC red,green
2 DEF blue,yellow
Table 2
id color value
1 red r
2 green g
3 blue b
4 yellow y
我怎样才能得到这样的提前
f1 f2 values
ABC red,green r,g
DEF blue,yellow b,y
感谢:
SELECT t1.f1,
t1.f2,
GROUP_CONCAT(t2.value) AS values
FROM TABLE_1 t1
JOIN TABLE_2 t2 ON FIND_IN_SET(t2.color, t1.f2)
GROUP BY t1.f1, t1.f2
你可以调整s CHEMA?我认为如果你有一个ABC对应颜色的映射表,它将会受益。
EG:
mapping_table
------------
id table1_id table2_id
1 1 1
2 1 2
这样,你可以很容易地做一个JOIN。
[FIND_IN_SET documentation](http://dev.mysql.com/doc/refman/5.0/en/string-functions.html#function_find-in-set) – 2010-09-22 03:45:56
亲爱的!它的部分权利。我试图执行你的查询,但它不返回任何结果集。你执行过这个吗? – Novice 2010-09-22 04:13:43
它的工作原理。谢谢 – Novice 2010-09-22 04:22:49