2010-09-22 2 views
0

У меня есть 2 таблицы, как этотMySql Select Query

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 

Заранее спасибо

ответ

3

Используйте GROUP_CONCAT function:

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/ru/string-functions.html#function_find-in-set) –

+0

Уважаемый! Это правильно. Я попытался выполнить ваш запрос, но он не возвращает никакого набора результатов. Вы выполнили это? – Novice

+0

Это работает. благодаря – Novice

1

Можете ли вы настроить s Чема? Я думаю, что это принесет пользу, если бы у вас была таблица сопоставлений любого ABC для цветов.

EG:

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

Таким образом, вы можете легко сделать JOIN.