zoukankan      html  css  js  c++  java
  • Invalid use of group function解决办法——MySQL

    Invalid use of group function即“集函数的无效用法”

    错句示例:SELECT sname AS '优秀学生姓名',AVG(score) as '平均成绩' FROM grade_info WHERE AVG(score)>90 GROUP BY sno;

    正确写法:SELECT sname AS '优秀学生姓名',AVG(score) as '平均成绩' FROM grade_info GROUP BY sno HAVING AVG(score) > 90 ;

    说明:

    GROUP BY,顾名思义:根据...分组,在SQL中常根据指定字段分组(指定字段内容相同是为一组),然后针对组进行相关操作

    WHERE和HAVING的区别在于:

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

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

    示例错句的问题就在于:WHERE子句中使用集函数。

    另外需要注意的地方是,SQL语法:

    SELECT [DISTINCT|DISINCTROW|ALL] select_expression,... -- 查询结果
    [FROM table_references -- 指定查询的表
    [WHERE where_definition] -- where子句,查询数据的过滤条件
    [GROUP BY col_name,...] -- 对[匹配where子句的]查询结果进行分组
    [HAVING where_definition] -- 对分组后的结果进行条件限制
    [ORDER BY{unsigned_integer | col_name | formula} [ASC | DESC],...] -- 对查询结果进行排序
    [LIMIT [offset,] rows] -- 对查询的显示结果进行条数限制
    [PROCEDURE procedure_name] --查询存储过程返回的结果集数据
    ]

    查询语句书写顺序须遵循上述规则。
    转自https://blog.csdn.net/bestforxu/article/details/51131234

  • 相关阅读:
    Scrapy中的POST请求发送和递归爬取
    爬虫之Scrapy框架
    linux下的python3,virtualenv,Mysql,nginx,redis安装配置
    Linu之linux系统基础优化和基本命令
    Linux之linux基础命令2
    Linux之linux基础命令
    Linux之linux入门
    Linux之服务器介绍
    Django之content_type
    Vue.js之路由系统
  • 原文地址:https://www.cnblogs.com/jva-index/p/13885507.html
Copyright © 2011-2022 走看看