6

我在 mysql 数据库中有两列,我想计算一个名称在两列中出现的次数。COUNT 函数本身对我不起作用,因为它只计算一列中的总数。

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 回答
0

如果单个名称在 1 列中出现 2 次及以上,则上述 sql 结果将是错误的。尝试在子查询中使用“distinct”语句。

于 2013-09-05T03:18:15.420 回答