转自:微点阅读  https://www.weidianyuedu.com

数据库having的用法的用法你知道吗?下面微点阅读小编就跟你们详细介绍下数据库having的用法的用法,希望对你们有用。

  数据库having的用法的用法如下:

  --sql中的group by 用法解析:

  -- Group By语句从英文的字面意义上理解就是“根据(by)一定的规则进行分组(Group)”。

  --它的作用是通过一定的规则将一个数据集划分成若干个小的区域,然后针对若干个小区域进行数据处理。

  --注意:group by 是先排序后分组;

  --举例子说明:如果要用到group by 一般用到的就是“每这个字” 例如说明现在有一个这样的表:每个部门有多少人 就要用到分组的技术

  select DepartmentID as '部门名称',

  COUNT(*) as '个数' from BasicDepartment group by DepartmentID

  --这个就是使用了group by +字段进行了分组,其中我们就可以理解为我们按照了部门的名称ID

  --DepartmentID将数据集进行了分组;然后再进行各个组的统计数据分别有多少;

  --如果不用count(*) 而用类似下面的语法

  select DepartmentID,DepartmentName from BasicDepartment group by DepartmentID

  --将会出现错误

  --消息 8120,级别 16,状态 1,第 1 行

  --选择列表中的列 'BasicDepartment.DepartmentName' 无效,因为该列没有包含在聚合函数或 GROUP BY 子句中。

  --这就是我们需要注意的一点,如果在返回集字段中,这些字段要么就要包含在Group By语句的后面,

  --作为分组的依据;要么就要被包含在聚合函数中。

  --出现的错误详解:咱们看看group by 的执行的过程,先执行select 的操作返回一个程序集,

  --然后去执行分组的操作,这时候他将根据group by 后面的字段

  --进行分组,并且将相同的字段并称一列数据,如果group by 后面没有这个字段的话就要分成好多的数据。

  --但是分组就只能将相同的数据分成两列数据,而一列中又只能放入一个字段,所以那些没有进行分组的

  --数据系统不知道将数据放入哪里,所以就出现此错误

  --目前一种分组情况只有一条记录,一个数据格是无法放入多个数值的,

  --所以这里就需要通过一定的处理将这些多值的列转化成单值,然后将其放在对应的

  --数据格中,那么完成这个步骤的就是聚合函数。这就是为什么这些函数叫聚合函数(aggregate functions)了

  --group by all语法解析:

  --如果使用 ALL 关键字,那么查询结果将包括由 GROUP BY 子句产生的所有组,即使某些组没有符合搜索条件的行。

  --没有 ALL 关键字,包含 GROUP BY 子句的 SELECT 语句将不显示没有符合条件的行的组。

  select DepartmentID,DepartmentName as '部门名称',

  COUNT(*) as '个数' from BasicDepartment group by all  DepartmentID,DepartmentName

  --group by 和having 解释:前提必须了解sql语言中一种特殊的函数:聚合函数,

  --例如SUM, COUNT, MAX, AVG等。这些函数和其它函数的根本区别就是它们一般作用在多条记录上。

  --WHERE关键字在使用集合函数时不能使用,所以在集合函数中加上了HAVING来起到测试查询结果是否符合条件的作用。

  create TABLE Table1

  (

  ID int identity(1,1) primary key NOT NULL,

  classid int,

  sex varchar(10),

  age int,

  )

  --添加测试数据

  Insert into Table1 values(1,'男',20)

  Insert into Table1 values(2,'女',22)

  Insert into Table1 values(3,'男',23)

  Insert into Table1 values(4,'男',22)

  Insert into Table1 values(1,'男',24)

  Insert into Table1 values(2,'女',19)

  Insert into Table1 values(4,'男',26)

  Insert into Table1 values(1,'男',24)

  Insert into Table1 values(1,'男',20)

  Insert into Table1 values(2,'女',22)

  Insert into Table1 values(3,'男',23)

  Insert into Table1 values(4,'男',22)

  Insert into Table1 values(1,'男',24)

  Insert into Table1 values(2,'女',19

  --举例子说明:查询table表查询每一个班级中年龄大于20,性别为男的人数

  select COUNT(*)as '>20岁人数',classid  from Table1 where sex='男' group by classid,age having age>20

  --需要注意说明:当同时含有where子句、group by 子句 、having子句及聚集函数时,执行顺序如下:

  --执行where子句查找符合条件的数据;

  --使用group by 子句对数据进行分组;对group by 子句形成的组运行聚集函数计算每一组的值;最后用having 子句去掉不符合条件的组。

  --having 子句中的每一个元素也必须出现在select列表中。有些数据库例外,如oracle.

  --having子句和where子句都可以用来设定限制条件以使查询结果满足一定的条件限制。

  --having子句限制的是组,而不是行。where子句中不能使用聚集函数,而having子句中可以。

数据库having的用法详细介绍相关推荐

  1. 【MADDPG(MPE)——环境配置与用法详细介绍(多智能体强化学习))】

    MADDPG(MPE)--环境配置与用法详细介绍(多智能体强化学习) MADDPG(MPE) 介绍 MPE环境安装教程 前期准备 MPE 安装包介绍 MPE 安装环境要求 开始安装 环境测试 MPE环 ...

  2. 数据库的锁的详细介绍

    数据库的锁和索引的详细介绍 数据库的锁的详细介绍 全局锁 表级锁 表锁 元数据锁 意向锁 行级锁 行锁 间隙锁 临键锁 数据库的锁的详细介绍 最近看了一下数据库的锁和索引的相关知识,写个博客加深一下记 ...

  3. Nacos注册中心的部署与用法详细介绍

    一.什么是注册中心: 我们知道微服务彼此间独立部署.具有清晰的边界,服务间通过远程调用来构建复杂的业务功能.而服务册中心在微服务项目中扮演着非常重要的角色,那么注册中心又是什么,使用服务注册中心可以解 ...

  4. php中sisson用法,详细介绍php中session的用法

    PHP中的session默认情况下是使用客户端的Cookie.当客户端的Cookie被禁用时,会自动通过Query_String来传递. Php处理会话的函数一共有11个,我们详细介绍一下将要用到几个 ...

  5. mysql 中show 命令用法详细介绍 mysql过程(procedure)的使用

    a. show tables或show tables from database_name; -- 显示当前数据库中所有表的名称 b. show databases; -- 显示mysql 中所有数据 ...

  6. js中typeof用法详细介绍

    本文章来介绍在js使用中的一个函数typeof用法, typeof 运算符把类型信息当作字符串返回,包括有大家常有变量类型. typeof 运算符把类型信息当作字符串返回.typeof 返回值有六种可 ...

  7. Thinkphp中import的几个用法详细介绍

    下面附上import的几个用法介绍 1.用法一 import('@.Test.Translate'); @,表示项目根目录.假定根目录是:App/ 导入类库的路径是:App/Lib/Test/Tran ...

  8. Nacos配置中心用法详细介绍

    上篇文章介绍了 Nacos 作为注册中心的用法,除此之外,Nacos 还能作为配置中心使用,那这篇文章就介绍下 Nacos 作为配置中心的基本用法,首先我们先了解下为什么需要使用配置中心. 一.为什么 ...

  9. while read line 用法详细介绍

    循环中的重定向 或许你应该在其他脚本中见过下面的这种写法: while read line do - done < file 刚开始看到这种结构时,很难理解< file是如何与循环配合在一 ...

最新文章

  1. shell 中柏开机显示efi_中柏 ezpad 平板安装Fedora 21 (Linux)
  2. 自然语言处理NLP之自然语言生成、文本相似性、看图说话、说话生图、语音合成、自然语言可视化
  3. 利用Trigger完成WPF 的动画-渐显
  4. Internet Explorer 8 使用技巧(2):加速器
  5. Python lambda用法及其与def的区别
  6. 网易游戏java_2019秋招|网易游戏一面面经(Java开发)
  7. 【腾讯云的1001种玩法】 Laravel 整合微视频上传管理能力,轻松打造视频App后台...
  8. ASP.NET的几个试题(《C#与.NET程序员面试宝典》)
  9. JAVA深入研究——Method的Invoke方法(转)
  10. 『中安网培』***游戏过关攻略
  11. 流媒体服务器开源方案调研
  12. 世纪佳缘与百合网结婚了!网络婚恋进入2.0时代 ?
  13. vertex系列芯片和zynq系列芯片结构的异同_使用ZYNQ实现复杂嵌入式系统,真的好用!...
  14. 如何选择隔离电源还是非隔离电源?
  15. Python函数设计与使用
  16. 【计算机网络】数据通信技术基础(数据通信性能指标、传输介质、数据交换技术、差错控制技术)
  17. 计算机语言的巴别塔——ANSI Unicode编码
  18. App Clips 新特性
  19. java simp,java – 自动装配SimpMessagingTemplate
  20. uniapp 电子印章_初探uni-app框架 踩坑

热门文章

  1. 【算法题】2309. 兼具大小写的最好英文字母
  2. [java]已知文件 source.txt 中的内容如下,其中,username、yonghu 都表示用户名,password、mima都表示密码,level、dengji都表示等级
  3. 苹果全球开发者大会将于6 月5日开幕
  4. 如何在线将CAD图纸文件进行转换成黑白PNG格式?
  5. 二项分布期望和方差的推导及推广
  6. python html模板引擎_flask入门2-模板引擎
  7. 2022-04-26 linux文件系统解读
  8. C# WinForms窗体淡出效果
  9. 原味的SM3密码杂凑算法
  10. 虚拟机构建局域网用户和组远程