加入收藏 | 设为首页 | 会员中心 | 我要投稿 源码门户网 (https://www.92codes.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

mssql 查询子句 MySql中where和having的区别

发布时间:2022-09-30 03:35:06 所属栏目:MsSql教程 来源:互联网
导读: 首先我们要清除一点,可以在不使用group by后面使用having,也可在from 表名 之后使用,就像 select * from emp having empno>1,这样写是没有错的,这一点要清楚。
1、where 后不能跟聚合函

首先我们要清除一点,可以在不使用group by后面使用having,也可在from 表名 之后使用,就像 select * from emp having empno>1,这样写是没有错的,这一点要清楚。

1、where 后不能跟聚合函数,因为where执行顺序大于聚合函数。

2、where 子句的作用是在对查询结果进行分组前,将不符合where条件的行去掉,即在分组之前过滤数据,条件 中不能包含聚组函数,使用where条件显示特定的行。

3、having 子句的作用是筛选满足条件的组,即在分组之后过滤数据,条件中经常包含聚组函数,使用having 条件显示特定的组,也可以使用多个分组标准进行分组。

where是在判断数据从磁盘读入内存的时候,而having是判断分组统计之前的所有条件mssql 查询子句,所以having是在对select查询的字段中进行的操作, 如:

我们创建一个员工表

然后进行查询,

这是在数据从磁盘读入内存的时候,进行的判断,不会出错。

这时会出错,因为前面并没有筛选出deptno字段 他会先查询出所有的记录到内存,形成了一个表,在对表进行操作,这是只能操作表中的字段,也就是select中有的字段。

(编辑:源码门户网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!