软件测试 | SQL语句中where与having的区别

  • 考察点:数据库
  • 难度:简单
  • 题目: 如果你在面试过程中,被面试官问到:请谈谈SQL语句中where与having的区别,你会如何回答呢?

简单来说,WHERE用于筛选整个表中的记录,HAVING用于筛选聚合函数(如COUNT, SUM, AVG)筛选分组后的记录。存在以下几点差异:1.一般情况下,WHERE 用于过滤数据行,而 HAVING 用于过滤分组。2.WHERE 查询条件中不可以使用聚合函数,而 HAVING 查询条件中可以使用聚合函数。3.WHERE 在数据分组前进行过滤,而 HAVING 在数据分组后进行过滤 。4.WHERE 针对数据库文件进行过滤,而 HAVING 针对查询结果进行过滤。也就是说,WHERE 根据数据表中的字段直接进行过滤,而 HAVING 是根据前面已经查询出的字段进行过滤。5.WHERE 查询条件中不可以使用字段别名,而 HAVING 查询条件中可以使用字段别名。

#软件测试##测试开发#
全部评论

相关推荐

评论
2
8
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务