MySQL自学笔记2--select的5个子句
2017-01-24 00:00
375 查看
摘要: 关于where、group by、having、order by、limit这5个select子句的相关知识。
MySQL自学笔记
使用的MySQL自带命令客户端,其中具体的操作是在自建的数据库下room303表中进行的,表中的列有:id、name、age、email、tel、salary、riqi、class。元组为自己随便添加的一些成员=.=!select子句
五种,包括:where、group by、having、order by、limitwhere:条件查询
where可以用在各种条件查询的场合,有如下一些常用的运算符<小于
>大于select * from room303where age > 22;!= 不等于(用<>也可以表示不等于)select * from room303where age <> 23;
<=小于等于
>=大于等于select name, age, riqi from room303where age >= 21;in(值1, 值2, 值3, ...) 表示在集合内的值都可以select * from room303where age in(20,23);between A1 and A2 表示介于A1、A2之间的值都可以,包括A1、A2select * from room303where age between 21 and 23;
* ``` MySQL select * from room303 where age not between 21 and 23;not(或者!) 表示逻辑非、or(或者||) 表示逻辑或、and(或者&&) 表示逻辑与select * from room303where age <=22 and salary between 1000 and 1800;
group by:分组查询
group by通常用在统计场合,一般用到如下的函数有这几个:max、min、sum、avg、countmax:求最大值select class, min(salary) from room303 group by class;min:求最小值sum:求和avg:求平均count:求总行数select class, count(age) from room303 group by class;``` MySQLselect class, count(*) from room303 group by class;上面两个获得的结果是一样的,因为count求的是总行数这里得注意的一点是在group by分组之后,max、min等想要找到的该列是正确的,但是对于获得的数据其他列中的值是group by分组后碰到的第一条记录!如果想要获得真正的结果,可以使用嵌套或者联合进行查询获得!
having:与where类似用于条件筛选
having后面接的语句与where类似,where后面的表达式怎么写,having就怎么写,但是两者之间有一个很重要的区别就是:where是针对表中的列进行筛选,查询数据having是针对查询结果中的列进行筛选,查询已经得到的结果中的数据简单的说:where对表起作用,having对结果进行筛选select * from room303where age >=22having salary < 1900;order by:排序
orde by可以用于各种排序场合,可以根据字段来进行升序(asc)或者降序(desc)的排列,默认是升序进行排列。排列可以按多字段来进行排列。多字段排序order by 列1 [desc/asc],列2 [desc/asc],...
select * from room303 order by age desc, salary asc;
limit:限制
limit放在语句的最后,用来限制条目用的,其格式如下:limit [offset]offset是偏移量(不写的话默认值为0),N是取出的条目数*``` MySQLselect * from room303 limit 1,2;
select五个子句的顺序问题
这5个select子句在SQL语句中是有顺序要求的,具体顺序为:where、
group by、
having、
order by、
limit
相关文章推荐
- MySQL中的integer 数据类型
- MySQL存储过程
- mysql中int、bigint、smallint 和 tinyint的区别与长度
- mysql load data 导出、导入 csv
- source命令执行SQL脚本文件
- MySQL创建用户及权限控制
- MySQL管理数据表
- linux下mysql添加用户
- mysql procedure
- mysql触发器
- 解决mysql 开启logbin 导致存储过程报错
- MySQL 备份和恢复策略
- mac下安装mysql(转载)
- mysql 修改编码 Linux/Mac/Unix/通用(杜绝修改后无法启动的情况!)
- MySQL数据的导出、导入(mysql内部命令:mysqldump、mysql)
- mysql数据行转列
- Linux下修改MySQL编码的方法
- MySQL Server 日志