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] --查询存储过程返回的结果集数据
]
相关文章
- 【MySQL】数据库介绍以及MySQL数据库
- Laravel 快速填充 MySQL 千万条数据
- Linux有问必答:如何在命令行创建一个MySQL数据库
- Ubuntu配置Apache+PHP+MySQL
- mysql 高级语法手记
- mysql数据库使用错误<errno:13>
- 发现个工具,查询Mongo数据使用mysql语法
- 基于Java+MySQL实现(界面)医院管理系统【100010723】
- MySql常见约束
- mysql issue:
- mysql之TIMESTAMP(时间戳)用法详解以及存在风险
- MySQL 8下忘密码后重置密码
- ubuntu16.04编译安装mysql-boost-5.7.21并编译成php扩展测试与使用
- MYSQL和ORACLE的触发器与存储过程语法差异
- MySQL 存储过程 经常使用语法
- 【1.2】mysql迁移实践及注意事项
- 【数据库】MySQL概念知识语法-基础(DDL/DML),真的很详细,一篇文章你就会了
- 【MySQL】查询数据库表、列、索引、事务信息等