mysqlcountunion_Mysql多表count查询
Mysql 多表count查询,这两天在做成就系统,成就中有很多维度都和数量有关,⽐如⽤户粉丝数达到多少50个,授予 名扬四海 称号,⽤
户点赞达到 100 次,授予 点赞圣⼿ 称号等等。
粉丝数在 user_relation 表
点赞数在 user_praise 表
按照以往的做法,如果需要查询⽤户的这些数据,⼜因为数据是在不同的表中,所以往往会分开多条 SQL 查询,⽐如:
eclipse内存大小设置
SELECT count(*) mysh FROM user_relation WHERE other_uid =123456;
SELECT count(*) dzss FROM user_praise WHERE praise_uid = 123456;
卵泡多大算成熟然后将查询出的数据封装在⼀个对象中,返回给客户端或者另做他⽤,如果需要统计的表少点还可以,但是像成就系统中,往往有各种各样
vboxmanage modifyvm
的成就,我们现在涉及到 12 张表,如果按照这种来查询,那么就要写 12 条 SQL 查询 12 次,这让⼈有点不爽。
能否⽤⼀条 SQL 语句实现呢
小程序案例源码答案是肯定的
像这种将多个表不同的数据,整合在⼀个表中的时候,我们可以采⽤ UNION操作。
⾸先将使⽤ UNION 改写以上语
句:12345678910111213SELECT wrzm,mysh,sgbh FROM (  SELECT count(*) wrzm,0 mysh,0 sgbh FROM user_witness WHERE pla
按照上⾯查询出来的结果为:
mysql_count_results
我们发现这个结果已经有点像样了,如果能将表中 wrzm ,mysh ,sgbh 的数据三⾏变成⼀⾏,那就好了。
于是我们很⾃然可以想到
⽤ SUM (当然⼀开始我没想到,经过朋友提醒),于是改写上⾯的 SQL
:12345678910111213SELECT sum(wrzm) wrzm,sum(mysh) mysh,sum(sgbh) sgbh FROM (  SELECT count(*) wrzm,0 mysh,0 sgb
c语言字符串输入输出
mysql语句多表查询
然后得出的结果为:
mysql_count_result_2
⾄此,得到了我们想要的结果,在⼀条 SQL 语句中实现了多个表的 count 统计。
我们想要的不⽌于此
如图,我们能获取到的仅仅是⼀个⽤户的数据,但是我们需要统计的是 user_info 中的所有⽤户,那么也很简单,我们再次进⾏改
写:12345678910111213141516SELECT uid,sum(wrzm) wrzm,sum(mysh) mysh,sum(sgbh) sgbh FR
OM (  SELECT plan_uid uid,co
查询结果为:
mysql_count_results_3
在这个结果中,如果我们需要查看具体某⼀个⽤户,那么在最后加上
WHERE uid = 123456 即可,如果要排序的话,那么直接加上 ORDER BY 即可。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。