2016-08-10 14 views
1

そこには2つのデータベーステーブルがあります。テーブル1 &テーブル2。異なるテーブルの2つのフィールドに基づいてテーブルの行列としてクエリ結果を取得することは可能ですか?異なるテーブルの2つのフィールドに基づく行列テーブルとしてのmysqlクエリの結果

Table_1 

| ID_PRODUCT | NAME_PRODUCT | 
|------------ |-------------- | 
| 1    | PRODUCT A  | 
| 2    | PRODUCT B  | 
| 3    | PRODUCT C  | 

Table_2 

| ID_SURVEY  | ID_PRODUCT | TOTAL SALES | 
|----------- |------------ |------------- | 
| 1    | 1    | 10   | 
| 1    | 2    | 20   | 
| 2    | 2    | 30   | 
| 2    | 3    | 40   | 
| 3    | 3    | 50   | 

予想される出力:

| ID_SURVEY  | PRODUCT A  | PRODUCT B  | PRODUCT C  | 
|----------- |----------- |----------- |----------- | 
| 1    | 10   | 20   | 0    | 
| 2    | 0    | 30   | 40   | 
| 3    | 0    | 0    | 50   | 

答えて

1

table_1が固定の製品を持っている場合、あなたは、このようにそれを行う

select 
    ID_SURVEY, 
    max(case when ID_PRODUCT = 1 then `TOTAL SALES` else 0 end) as `PRODUCT A`, 
    max(case when ID_PRODUCT = 2 then `TOTAL SALES` else 0 end) as `PRODUCT B`, 
    max(case when ID_PRODUCT = 3 then `TOTAL SALES` else 0 end) as `PRODUCT C` 
from Table_2 
group by ID_SURVEY 

Demo Here

しかし、ここでは、動的SQLを使用することができますこれを行うには:

SET @sql = NULL; 
SELECT 
    GROUP_CONCAT(DISTINCT 
    CONCAT(
     'MAX(CASE WHEN t2.ID_PRODUCT = ', 
     t2.ID_PRODUCT, 
     ' THEN t2.`TOTAL SALES` ELSE 0 END) AS `', 
     t1.NAME_PRODUCT, '`' 
    ) 
) INTO @sql 
FROM Table_2 t2 
JOIN Table_1 t1 
ON t2.ID_PRODUCT = t1.ID_PRODUCT; 
SET @sql = CONCAT('SELECT t2.ID_SURVEY, ', @sql, 
        ' FROM Table_2 t2 
        JOIN Table_1 t1 
        ON t2.ID_PRODUCT = t1.ID_PRODUCT 
        GROUP BY t2.ID_SURVEY'); 

PREPARE stmt FROM @sql; 
EXECUTE stmt; 
DEALLOCATE PREPARE stmt; 

Demo Here

関連する問題