6

mysql データベースに 2 つの列があり、両方の列に 1 つの名前が表示される回数を数えたいと考えています。COUNT 関数自体は、1 つの列の合計のみをカウントするため、機能しません。

MySql 列:

+-----------------+--------------+
| Member1         | Member2      |
+-----------------+--------------+
| John            | Bill         | 
| Bill            | John         |
| Joe             | John         |
| Bill            | Joe          |
| John            | Steve        |
+-----------------+--------------+

望ましい出力:

+-----------------+--------------+
| Member          |     Total    |
+-----------------+--------------+
| John            | 4            | 
| Bill            | 3            |
| Joe             | 2            |
| Steve           | 1            |
+-----------------+--------------+

何か案は??ありがとう!

4

2 に答える 2

10

以下を使用すると、UNION ALL. 単一の列になったら、集計関数を適用できますcount

select member, count(*) Total
from 
(
  select member1 as member
  from yt
  union all
  select member2
  from yt
) d
group by member
order by total desc;

デモで SQL Fiddle を参照してください

于 2013-04-30T12:26:03.677 に答える