2010-09-22 97 views
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 

我怎样才能得到这样的提前

回答

3

使用GROUP_CONCAT function

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 
+0

[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

+0

亲爱的!它的部分权利。我试图执行你的查询,但它不返回任何结果集。你执行过这个吗? – Novice 2010-09-22 04:13:43

+0

它的工作原理。谢谢 – Novice 2010-09-22 04:22:49

1

你可以调整s CHEMA?我认为如果你有一个ABC对应颜色的映射表,它将会受益。

EG:

mapping_table 
------------ 
id table1_id table2_id 
1 1   1 
2 1   2 

这样,你可以很容易地做一个JOIN。