MySQL中的having和where的区别

HAVING 和 WHERE 是 SQL 查询中用于筛选数据的两个关键字,但它们在使用时有一些区别:

WHERE 子句:

1用于在查询执行之前对原始数据进行筛选。

2作用于单行数据,过滤不满足条件的数据行。

3在对单个行进行判断和过滤时使用,例如基于行的条件筛选。

HAVING 子句:

1用于在数据分组之后对分组结果进行筛选。

2通常与 GROUP BY 一起使用,用于对分组后的数据进行条件筛选。

3作用于分组数据,过滤不满足条件的分组。

4在对分组结果进行聚合后的条件筛选时使用,例如基于聚合结果的条件筛选。

示例:

假设有一个表格 Sales 包含销售订单的信息,包括订单号、产品、数量和金额等。我们想要找到销售数量大于 100 且订单总金额大于 1000 的产品。

表格 Sales:

复制代码
+------+--------+----------+--------+
| OrderID | Product | Quantity | Amount |
+------+--------+----------+--------+
| 1      | A      | 50       | 500    |
| 2      | B      | 150      | 1500   |
| 3      | A      | 200      | 2000   |
| 4      | C      | 80       | 800    |
+------+--------+----------+--------+
使用 WHERE 子句的查询:

SELECT Product, SUM(Quantity) AS TotalQuantity
FROM Sales
WHERE Quantity > 100 AND Amount > 1000
GROUP BY Product;
使用 HAVING 子句的查询:


SELECT Product, SUM(Quantity) AS TotalQuantity
FROM Sales
GROUP BY Product
HAVING SUM(Quantity) > 100 AND SUM(Amount) > 1000;
在这个示例中,WHERE 子句用于在查询执行之前对原始数据进行筛选,而 HAVING 子句用于在对数据进行分组后对分组结果进行筛选。
相关推荐
chxii23 分钟前
ISO 8601日期时间标准及其在JavaScript、SQLite与MySQL中的应用解析
开发语言·javascript·数据库
bug攻城狮2 小时前
SaaS多租户架构实践:字段隔离方案(共享数据库+共享Schema)
mysql·架构·mybatis·springboot·1024程序员节
小丁爱养花2 小时前
Redis 内部编码/单线程模型/string
数据库·redis·缓存·1024程序员节
l1t3 小时前
利用DuckDB SQL求解集合数学题
数据库·sql·算法·集合·duckdb
siriuuus3 小时前
MySQL 慢查询日志及优化
mysql·1024程序员节
筵陌3 小时前
MYSQL表的操作
数据库·mysql·1024程序员节
一 乐3 小时前
汽车销售|汽车推荐|基于SprinBoot+vue的新能源汽车个性化推荐系统(源码+数据库+文档)
java·数据库·vue.js·汽车·毕设·汽车个性化推荐
虾说羊3 小时前
最细Maven教程以及Maven私服搭建
java·数据库·maven
RestCloud3 小时前
Kingbase与ETL:如何实现金融级数据库的安全数据同步
数据库