MySQL 运算符主要包括 3 大类:比较运算符、算术运算符、逻辑运算符。
算术运算符
加 + 、减 - 、乘 * 、除 / 、求余 %
比较运算符
运算符 | 语法 | 说明 |
= | a=b | 如果参与计算的两个操作数相等则为 true ,否则 false |
!= 或者 <> | a!=b 或者 a<>b | 如果两个操作数不相等则 true[1] ,否则 false[0] |
> | a>b | 如果 a 大于 b 则 true |
<= | a<=b | 小于等于 |
>= | a>=b | 大于等于 |
in 或者 not in
in 用于判断某个列的取值是否为指定的值,使用 in 运算符时指定的值是离散的数据,不是连续值。
select * from tb_student where age in(18,28,15) 含义是`age=18 or age=28 or age=15`
select * from tb_student where age not in(18,28,15) 含义是`age!=18 and age!=28 and age!=15
between/and
用于判断数据是否在指定的范围内,连续值。
查询成绩及格并且不属于优秀的所有学生信息
select * from tb_student where score>=60 and score<=85;
select * from tb_student where score between 60 and 85;
逻辑运算符
语法 | 说明 | |
&& 或者 and | a and b 或者 a&&b | 逻辑与,如果参与计算的两个操作数为 true ,否则 false |
|| 或者 or | a or b 或者 a || b | 逻辑或,如果参与计算的双反,只要一方为 false ,则返回 false |
not 或者 ! | not a 或者 !a | 逻辑非,如果操作数为 false 则结果为 true |
聚集函数
聚集函数用于对于一个集合中的数据进行处理,不是一行一行的数据。
count 统计行数、sum 求和、max 最大值、min 最小值、avg 平均值
对查询结果分组
可以使用 group by 子句对查询结果进行分组处理,经常会使用聚集函数
1、如果不使用分组,聚集函数则用于处理所有查询结果数据
2、如果使用分组,则分别作用于各个分组查询的结果数据
having 分组条件
having 对分组进行条件选择 having 条件
排序处理
语法:select ... from ... order by 列名称 1 [asc/desc],列名称 2 [asc/desc],...
asc 正序自然序,desc 逆序。默认 asc
查询学生信息,要求按照年龄倒排序,如果年龄相等,则按照姓名排序
select * from tb_student order by age desc,name;
1、排序过程中首先按照列名称 1 进行排序,如果列 1 对应值相等时,才按照列名称 2 对应列值进行排序。
2、注意默认按照指定列的自然序排序,如果需要倒序则使用关键字 desc,asc 是正序。