sql语句:having子句与where子句用法与区别
having子句也是设定条件的语句与where有相似之处但也有区别。having子句在查询过程中慢于聚合语句(sum,min,max,avg,count).而where子句在查询过程中则快于聚合语句(sum,min,max,avg,count)
简单说来:
where子句:

  1. select sum(num) as rmb from order where id>10
  2. //只有先查询出id大于10的记录才能进行聚合语句

having子句:

  1. select reportsto as manager, count(*) as reports from employees
  2. group by reportsto having count(*) > 4


以northwind库为例.having条件表达示为聚合语句。肯定的说having子句查询过程慢于聚合语句。
再换句说话说把上面的having换成where则会出错。统计分组数据时用到聚合语句。
对分组数据再次判断时要用having。如果不用这些关系就不存在使用having。直接使用where就行了。
having就是来弥补where在分组数据判断时的不足。因为where要快于聚合语句。说的应该是很明白了。

, , ,

Del.icio.us Google书签 Digg Live Bookmark Technorati Furl Yahoo书签 Facebook 百度搜藏 新浪ViVi 365Key网摘 天极网摘 和讯网摘 博拉网 POCO网摘 添加到饭否 QQ书签 Digbuzz我挖网

4 Comments so far...

  1. Jude

    对我很有帮助,谢谢!

  2. Cngothic

    不客气.
    自己的一些总结能帮上你我也很高兴.

  3. hhf

    查来查去,原来我想要的答案在这儿!
    谢谢!

  4. cngothic

    呵呵

Leave a reply?

Logged in as cngothic. Logout »