MySQL学习笔记 第六讲:select语句order by、limit、distinct、union

第六讲: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字段数必须一致,数据类型也要求一致。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值