Invalid use of group function解决办法
在做sql习题时多次遇到这个问题,忍不了了百度了解决办法,原来还是自己的基础知识没有掌握扎实,记录下来便于以后学习~

select a.Cname,count(b.S) from Course a left join SC b on a.C = b.C where count(b.S) = 2 group by a.Cname;
改成这一句问题就解决了
select a.Cname,count(b.S) from Course a left join SC b on a.C = b.C group by a.Cname having count(b.S) = 2;
需要学习的知识点:
where 子句的作用是对查询结果进行分组前,将不符合where条件的行去掉,即在分组之前过滤数据,where条件中不能包含聚组函数,使用where条件过滤出特定的行。
having 子句的作用是筛选满足条件的组,即在分组之后过滤数据,条件中经常包含聚组函数,使用having 条件过滤出特定的组,也可以使用多个分组标准进行分组。