zoukankan      html  css  js  c++  java
  • Where/Order by/Ggroup by/Having使用的注意事项

    1、Where、Order by、Group by 、having

    Where作用对象是:基本表或视图,从中选出符合条件的元素。

    Order by 作用对象是:基本表或视图,就是排序方式,分为升序(ASC)和降序(DESC),排序默认为升序

    Group by 作用对象是:基本表或视图,把对象进行分组(一个或多个字段)。

    Having 作用对象是 组,从中选择符合条件的组

    注意事项:

    1. Group by 与having连用选出符合条件的分组;
    2. Group by 必须与聚合函数(sum,avg,min,max,cout)一起使用才有意义,使用时至少需要一个分组标志;
    3. Group by 与Where 一起使用时:

    【3.1】一起使用时,where在前group by 在后;

    【3.2】注意having和where的用法区别;

              (3.2.1)having只能用在group by 之后,对分组的结果进行筛选{即使用having的前提条件是分组};

               (3.2.2)where肯定再group by之前;

               (3.2.3)where后的条件表达式里不允使用聚合函数,而having可以;

    【3.3】当一个查询语句同事出现了where,group by,having,order by的时候,执行顺序和编写顺序是:

    <Where--group by---having--order by>

    (1) 执行where xx对全表数据做筛选,返回第1个结果集。

    (2) 针对第1个结果集使用group by分组,返回第2个结果集。

    (3) 针对第2个结果集中的每1组数据执行select xx,有几组就执行几次,返回第3个结果集

    (4) 针对第3个结集执行having xx进行筛选,返回第4个结果集。

    (5) 针对第4个结果集排序。

  • 相关阅读:
    学习winform第三方界面weiFenLuo.winFormsUI.Docking.dll
    C#中MySQL数据库的备份 还原 初始化
    winform学习笔记02
    mysql与sqlserver之间的关系转换
    mysql数据库使用
    python学习--导入自己的包
    thymeleaf 拼接 超链接
    @RequestParam与@PathVariable的区别
    ifram 实现左侧菜单,右侧显示内容
    Spring 整合Shiro:记住我
  • 原文地址:https://www.cnblogs.com/songtzh/p/12007056.html
Copyright © 2011-2022 走看看