数据库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)了   https://www.weidianyuedu.com

  --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. 关于数据库having的用法的详细介绍

    转自:微点阅读  https://www.weidianyuedu.com 数据库having的用法的用法你知道吗?下面小编就跟你们详细介绍下数据库having的用法的用法,希望对你们有用. 数据库h ...

  2. 数据库having的用法详细介绍

    转自:微点阅读  https://www.weidianyuedu.com 数据库having的用法的用法你知道吗?下面微点阅读小编就跟你们详细介绍下数据库having的用法的用法,希望对你们有用. ...

  3. 数据库 SQLServer中GUID用法介绍

    数据库 SQLServer中GUID用法介绍 1.NEWID用法 NEWID()作用是生成无顺序的GUID字符串.用法如下: SELECT NEWID() --生成36位的GUID SELECT RE ...

  4. pm2常用的命令用法介绍

    pm2 是一个带有负载均衡功能的Node应用的进程管理器.当你要把你的独立代码利用全部的服务器上的所有CPU,并保证进程永远都活着,0秒的重载, PM2是完美的,下面我们来看pm2常用的命令用法介绍吧 ...

  5. 什么是mysql的游标_MySQL游标概念是什么 MySQL游标概念与用法介绍

    本篇文章小编给大家分享一下MySQL游标概念与用法介绍,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看. 1.游标的概念(Cursor) 一条sql,对应N条资源,取出资源的接 ...

  6. mysql数据库replace写入_MySQL数据库replace into 用法(insert into 的增强版)

    MySQL数据库replace into 用法我以前介绍过相关的教程,但有加强版各位朋友可能不知道吧,今天我们来看一篇关于MySQL数据库replace into增强版的介绍与用法例子. Error ...

  7. lsof 命令实用用法介绍

    Table of Contents 前言 Linux 下有哪些文件 lsof 命令实用用法介绍 查看当前打开的所有文件 列出被删除但占用空间的文件 恢复打开但被删除的文件 查看当前文件被哪些进程打开 ...

  8. CC#中List用法介绍详解学习通http://www.bdgxy.com/roundWorker类用法总结学习通http://www.bdgxy.com/

    文章来源: 学习通http://www.bdgxy.com/ 普学网http://www.boxinghulanban.cn/ 智学网http://www.jaxp.net/ 表格制作excel教程h ...

  9. Oracle数据库之rownum,ORACLE数据库中Rownum用法详解

    ORACLE 中ROWNUM用法总结! 对于 Oracle 的 rownum 问题,很多资料都说不支持>,>=,=,between...and,只能用以上符号(,& gt;=,=, ...

最新文章

  1. 关于前端使用JavaScript无法实现canvas打印问题的解决
  2. springboot aop使用_Spring Boot 的自动配置,是如何实现的?
  3. ICML 2018 | 腾讯AI Lab详解16篇入选论文
  4. java poi exce 移动_JAVA使用POI操作excel
  5. FreeBSD大败局
  6. plt.subplots中的ax = ax.flatten()
  7. python改变turtle画笔方向的函数_哪个选项不能改变turtle画笔的运行方向?
  8. Rust 2018临近:设法从Rust 2015过渡
  9. 用python画大白圣诞快乐呦
  10. 推荐模块︱apple.Turicreate个性化推荐recommender(五)
  11. android实现qq登录功能实现原理,Android实现QQ登录功能
  12. tcp/ip ---IP路由选择
  13. 下载Chrome浏览器历史版本方法
  14. 图像增强——Roberts算子、Sobel算子、Prewitt算子、Laplace算子
  15. 聚类分析原理及R语言实现过程
  16. c语言 电阻器的分类,电阻器的分类与特点
  17. 打开Excel2010时提示错误:向程序发送命令时出现问题!
  18. 如何设置对话框的最大(小)高度与宽度
  19. 大众疑问:学会PS 可以找什么工作
  20. Linux 环境下iSCSI Target 与 Initiator 配置

热门文章

  1. python stdout_将stdout重定向到Python中的文件?
  2. 用PPT制作精美写真集
  3. html表格查找,js实现表格数据搜索
  4. iOS14系统下按钮点击没有反应
  5. 解决密码框显示和掩藏密码
  6. web应用开发课程设计 HTML+CSS制作奶茶网站
  7. 计算机毕业设计ssm小学教师网络培训网站ea3c0系统+程序+源码+lw+远程部署
  8. ARM调试(2):在keil利用指令跟踪宏单元(ITM)重定向printf,并完成scanf实现数据双向交互
  9. vue 中使用element-ui的menu选中项高亮的问题
  10. leetCode-289. 生命游戏