having 方法与 where 的区别是什么?

$users = DB::table('users')
                ->groupBy('account_id')
                ->having('account_id', '>', 100)
                ->get();

文档中,关于groupBy()->having()方法中,对于having()方法,只是说与where()十分类似。那么两者有什么区别?

《L01 基础入门》
我们将带你从零开发一个项目并部署到线上,本课程教授 Web 开发中专业、实用的技能,如 Git 工作流、Laravel Mix 前端工作流等。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 Laravel。
流浪剑客
最佳答案

HAVING 子句通常与 GROUP BY 子句一起使用,以根据指定的条件过滤分组。HAVING 子句将过滤条件应用于每组分行,而 WHERE 子句将过滤条件应用于每个单独的行。

5年前 评论
wesen (楼主) 5年前
讨论数量: 3

//where查询

$where=IconHandleLog::where('icon_id',1)->get();

//having查询

$having=IconHandleLog::groupBy('icon_id')->select('id','icon_id',DB::raw('sum(num) as num_all'))->having('num_all','>',20)->get();

5年前 评论
wesen (楼主) 5年前
流浪剑客

HAVING 子句通常与 GROUP BY 子句一起使用,以根据指定的条件过滤分组。HAVING 子句将过滤条件应用于每组分行,而 WHERE 子句将过滤条件应用于每个单独的行。

5年前 评论
wesen (楼主) 5年前

having 是你where筛选出来后的结果再次筛选。。。我是这么理解的

5年前 评论
lddtime 5年前
sunrise丶 (作者) 5年前

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!