MySQL学习笔记 第六讲:select语句order by、limit、distinct、union
2013-07-14 21:00
826 查看
第六讲:select语句order by、limit、distinct、union
1.order by:按照字段值进行排序
①语法:order by 字段 升序|降序 (asc|desc)(默认升序)
②校对规则:决定排序关系,允许多字段排序(先按照第一个字段排序,不能区分才能使用第二个字段)
例:select * from tbl_name order by class_id asc,class_no desc;
注:如果是分组,则应使用对分组字段进行排序的group by语法
2.limit:限制获得记录的数量
语法:limit offset,row_count;
offset:偏移量,从0开始,可以省略,默认是零;
row_count:总记录数,如果数量大于余下数,则获取余下所有即可
注:索引位置从0开始
例:select * from tbl_name limit 3,4;(从第四条开始,检索4条数据)
3.distinct:去除重复记录
select distinct class_days from teacher_class;
重复记录指的是字段值都相同的记录,而不是部分字段相同的记录
4.union:联合查询
将多余select语句的结果,合并到一起,称为联合操作,使用union关联字联合多个select语句即可。
例:(select t_name,days from teacher_class where c_name = 'php115' order by days desc limit 1)
union
(select t_name,days from teacher_class where c_name = 'php228' order by days desc limit 1);
场景:获得数据条件,出现逻辑冲突,或者很难在一个逻辑内表达,就可以拆分成多个逻辑分别实现,最后将结果合并到一起。
注:①如果union的结果存在重复记录,会消除重复,可以通过union all达到目的
②排序:子语句查询结果排序:将子语句包裹在括号内;
子语句的order by只有配合limit时才有效,原因是union做子语句会对没有limit的order by优化(忽略);
对所有结果进行排序 ,只需在最后一个select语句后添加相应的排序规则;
规定:多个检索的select字段数必须一致,数据类型也要求一致。
1.order by:按照字段值进行排序
①语法:order by 字段 升序|降序 (asc|desc)(默认升序)
②校对规则:决定排序关系,允许多字段排序(先按照第一个字段排序,不能区分才能使用第二个字段)
例:select * from tbl_name order by class_id asc,class_no desc;
注:如果是分组,则应使用对分组字段进行排序的group by语法
2.limit:限制获得记录的数量
语法:limit offset,row_count;
offset:偏移量,从0开始,可以省略,默认是零;
row_count:总记录数,如果数量大于余下数,则获取余下所有即可
注:索引位置从0开始
例:select * from tbl_name limit 3,4;(从第四条开始,检索4条数据)
3.distinct:去除重复记录
select distinct class_days from teacher_class;
重复记录指的是字段值都相同的记录,而不是部分字段相同的记录
4.union:联合查询
将多余select语句的结果,合并到一起,称为联合操作,使用union关联字联合多个select语句即可。
例:(select t_name,days from teacher_class where c_name = 'php115' order by days desc limit 1)
union
(select t_name,days from teacher_class where c_name = 'php228' order by days desc limit 1);
场景:获得数据条件,出现逻辑冲突,或者很难在一个逻辑内表达,就可以拆分成多个逻辑分别实现,最后将结果合并到一起。
注:①如果union的结果存在重复记录,会消除重复,可以通过union all达到目的
②排序:子语句查询结果排序:将子语句包裹在括号内;
子语句的order by只有配合limit时才有效,原因是union做子语句会对没有limit的order by优化(忽略);
对所有结果进行排序 ,只需在最后一个select语句后添加相应的排序规则;
规定:多个检索的select字段数必须一致,数据类型也要求一致。
相关文章推荐
- mysql---select的五种子句学习(where、group by、having、order by、limit)
- MySql学习笔记1:select语句
- Mysql DBA 高级运维学习笔记-DQL语句之select知识讲解
- mysql---select的五种子句学习(where、group by、having、order by、limit)
- MySQL学习笔记(10)之select查询语句
- mysql学习笔记(三)select语句
- (MySQL笔记)SELECT语句的WHERE子句详解
- MYSQL语句+索引+忘记密码+解决乱码+二进制日志 -学习笔记
- MySql学习笔记4:模糊匹配语句
- mysql查询语句select-limit使用详解
- (MySQL笔记)SELECT语句的WHERE子句详解
- mysql语句 学习笔记(二)
- MySQL处理同时存在order by 和 limit 语句时出现的bug
- MySQL查询优化:连接查询排序limit(join、order by、limit语句)
- MySql学习笔记(4)--SQL(DML)语句语法
- Mysql 简单的命令语句续-*,as,group by,order by,group by,having,limit;
- 3.笔记 MySQL学习——简单执行SQL语句
- 73.笔记 MySQL学习——C编写MySQL程序六交互式语句执行
- MySQL查询优化:连接查询排序limit(join、order by、limit语句)
- sql 语句中 id< ;SELECT * FROM t_blog WHERE id<#{id} ORDER BY id DESC LIMIT 1