MySQLのマージは、複数の列を数えます

Kagami Ryushi :

私はこのようなテーブル(tb_data)を持っています

+---------+---------------------+---------------------+---------------------+---------------------+ 
| Disease | Additional_Disease1 | Additional_Disease2 | Additional_Disease3 | Additional_Disease4 |
+---------+---------------------+---------------------+---------------------+---------------------+ 
| A01     | A03                 | A03                 |                     |                     |
| A03     | A02                 |                     |                     |                     |
| A03     | A05                 |                     |                     |                     |
| A03     | A05                 |                     |                     |                     |
| A02     | A05                 | A01                 | A03                 |                     | 
+---------+---------------------+---------------------+---------------------+---------------------+ 

私の質問は、このようにそれを作成する方法であります

+---------+-------+ 
| Disease | Total |
+---------+-------+
| A03     | 6     |
| A05     | 3     |
| A01     | 2     |
| A02     | 2     |
+---------+-------+

とまあ、ここで私の失敗の試みです

select Disease, 
count(Disease + Additional_Disease1 + Additional_Disease2 + Additional_Disease3 + Additional Disease_4) as Total
from tb_data
group by Disease
order by Disease desc

私も試してみたこれをそれはうまくいきませんでした、私は本当に間違っていたかを理解していないとして、それは『フィールドリスト』に「不明な列『病』と言います

GMB:

あなたは使用することができunion all、あなたのデータセット、その後、凝集をアンピボットします:

select disease, count(*) total
from (
    select disease from mytable
    union all select additional_disease1 from mytable
    union all select additional_disease2 from mytable
    union all select additional_disease3 from mytable
    union all select additional_disease4 from mytable
) t
group by disease
order by total desc, disease

おすすめ

転載: http://43.154.161.224:23101/article/api/json?id=21322&siteId=1