{eval=Array;=+count(Array);}
既然两个表的结构一模一样,如果想统计人名出现的总数,可以将两个表先用union all合并到一起,然后再对其进行统计。
例如,有下面两个表:成绩表A、成绩表B,这两个表的结构是完全一样的,分别都有20条记录,但两个表有部分记录是重复的:
如果将两个表合并到一起,可以使用union all。注意,这里必须加上all,否则,那些重复的记录就会被排除掉了,从而导致出现的总数不准确。例如,下面的语句没有加all,输出的姓名记录数只有25个,有另外15个重复的被排除掉了:
所以,一定要加上all。这样得到两个表的合集后,再用括号将其包起来,把它作为一个表来处理,再次统计即可。sql语句如下:
select 姓名,count(*) as 出现次数 from (select 姓名 from 成绩表A union all select 姓名 from 成绩表B) group by 姓名
统计结果如下图:
我是人民邮电出版社签约作者,著有多本与B/S、C/S开发方面的专业书籍,欢迎关注并一起交流提高,谢谢!
SQL多表查询,一般都是用连接进行表之间的连接,那样会把所有表统一行程一张大表或者视图进行查询,那样方便你的查询;
查询之后,根据你的需求进行order by或者group by统计你想要的数据;
如有不明白的地方,可以关注我并且私聊我!
0
回答0
回答0
回答0
回答0
回答0
回答0
回答0
回答0
回答0
回答