在Oracle中where和having的区别-创新互联

    首先,where是针对单个语句的,having是针对组的。并且优先级是where>group by>having.

公司主营业务:成都做网站、成都网站制作、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联公司是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联公司推出民勤免费做网站回馈大家。

    需要注意的是:

1.where 是不可以放在group by 之后的

2.having 和group by 连用,并且 放在group by 之后

3.where 之后不可聚合函数,即SUM( ) ,AVG( ) 等等。having可以。

聚合函数:

    聚合函数就是统计函数。比如求和、求平均值、大最小之类的。而group by 可以对这些统计函数对一组数据起作用。比如,我需要求各个阶段内的平均值,则需要最各个阶段进行分类,然后求平均。当然,where 也是可以达到要求的。

    在查询中,聚合语句(聚合函数)优先级要高于having(即先分类在统计),聚合语句的优先级低于where()即先单个筛选再进行统计。比如,我们要对部门中小于20的部门并且工资之和要大于10000的部门进行筛选。则:

select department_id, sum(salary) from group where department_id < 20 group by department_id having sum(salary) >10000;

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


当前标题:在Oracle中where和having的区别-创新互联
URL分享:http://scyanting.com/article/diegpp.html