zoukankan      html  css  js  c++  java
  • 数据库中where与having区别

    在初学数据库的时候,会经常用到一些数据库语句去查询数据库中的表,不管是oracle、mysql、db2、还是sqlserver,数据库的语法都大同小异。而在使用sql语句的过程中,会经常遇到一些问题,诸如数据库中where与having区别?

    数据库中where与having区别
     

    工具/原料

     
    • 数据库

    方法/步骤

     
    1.  

      当然,在数据库中,如何正确的使用where与having,首先,要弄清楚这两个名词在数据库中的定位。where在sql中是一个约束声明,使用where来约束数据库的数据。

      数据库中where与having区别
    2.  

      having是一个过滤声明,是在查询返回结果集以后对查询结果进行的过滤操作。此外,区别两个名词的还有一个分组,就是group by,where条件是不需要分组的,在分组之前过滤数据,所以where字句中不包含聚组函数。

      数据库中where与having区别
    3.  

      而having是要配合group by 使用,在分组之后过滤数据。所以总结一句话,

      where在group by之前执行,having 在group by 之后执行。where和having 可以同时存在一个SQL语句中。

      数据库中where与having区别
    4.  

      在这里做一个简单的例子,这边有一张sales表格,里面有name,sex,salary,dept四个字段,通过select × from sales可以查询到表中所有的内容。

      数据库中where与having区别
    5.  

      然后接下来使用where查询性别为男性的所有数据,具体的语句为:select * from sales where sex='男'。这里面就是使用where来进行筛选,不需要进行组合语句。

      数据库中where与having区别
    6.  

      然后使用having,这里面的having是一定要配合group by 一起使用的,而where可有可无,然后having是基于对表进行分组之后,然后再进行筛选。

      数据库中where与having区别
    7. 7

      以上就是where 与having的具体用法,明白了吗?

  • 相关阅读:
    函数 定义与调用
    python文件基本操作(读,写,追加)
    python集合深浅copy
    day6 bytes类型用法
    字典的增删改查
    一个文件启动Django(基础中的基础)
    Django错误集
    Linux的Shell
    Linux的Vim文本编辑器
    Linux管道符和重定向与环境变量
  • 原文地址:https://www.cnblogs.com/muhy/p/10571583.html
Copyright © 2011-2022 走看看