统计字段出现次数

MySql 码拜 8年前 (2016-02-15) 809次浏览
假设本人有两个表
table1
id value
1 张三,李四
2 张三,王五
3 张三 马六
table2
id name
1 张三
2 李四
3 王五
4 马六
现在本人想统计table2中全部的人在table1中出现的次数,结果应该是这样的
张三 3
李四 1
王五 1
马六 1
求高手指点
解决方案

5

也是新手,感觉四次挺麻烦的,期待更好的方法以供学习。
select name,count from (SELECT count(*) as count from table1 a where length(value)-length(replace(value,(SELECT name from table2 where id = 1),””))) a
CROSS JOIN
(SELECT name from table2 where id = 1) b
UNION
select name,count from (SELECT count(*) as count from table1 a where length(value)-length(replace(value,(SELECT name from table2 where id = 2),””))) a
CROSS JOIN
(SELECT name from table2 where id = 2) b
UNION
select name,count from (SELECT count(*) as count from table1 a where length(value)-length(replace(value,(SELECT name from table2 where id = 3),””))) a
CROSS JOIN
(SELECT name from table2 where id = 3) b
UNION
select name,count from (SELECT count(*) as count from table1 a where length(value)-length(replace(value,(SELECT name from table2 where id = 3),””))) a
CROSS JOIN
(SELECT name from table2 where id = 4) b

10

select table2.name,count(*)
from table2 , table1
where find_in_set(table2.name,table1.value)

5

select table2.name,count(*)
from table2 , table1
where find_in_set(table2.name,table1.value)
group by table2.name

CodeBye 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权 , 转载请注明统计字段出现次数
喜欢 (0)
[1034331897@qq.com]
分享 (0)