前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【mysql】order by排序

【mysql】order by排序

原创
作者头像
兮动人
发布2022-03-03 09:02:22
2.4K0
发布2022-03-03 09:02:22
举报
文章被收录于专栏:兮动人的博客

排序数据

1. 排序规则

  • 如果没有使用排序操作,默认情况下查询返回的数据是按照添加数据的顺序显示的。
  • 使用 ORDER BY 对查询到的数据进行排序操作。
  • 使用 ORDER BY 子句排序
    • ASC(ascend): 升序
    • DESC(descend):降序
  • ORDER BY 子句在SELECT语句的结尾。

2. 单列排序

  • 按照salary从高到低的顺序显示员工信息
代码语言:sql
复制
SELECT employee_id,last_name,salary
FROM employees
ORDER BY salary DESC;
在这里插入图片描述
在这里插入图片描述
  • 可以使用列的别名,进行排序
代码语言:sql
复制
SELECT employee_id,salary,salary * 12 annual_sal
FROM employees
ORDER BY annual_sal;
在这里插入图片描述
在这里插入图片描述
  • 注意:列的别名只能在 ORDER BY 中使用,不能在WHERE中使用。
  • 如下操作报错:
代码语言:sql
复制
SELECT employee_id,salary,salary * 12 annual_sal
FROM employees
WHERE annual_sal > 81600;
在这里插入图片描述
在这里插入图片描述
  • 强调格式:WHERE 需要声明在FROM后,ORDER BY之前
代码语言:sql
复制
SELECT employee_id,salary,department_id
FROM employees
WHERE department_id IN (50,60,70)
ORDER BY department_id DESC;
在这里插入图片描述
在这里插入图片描述

3. 多列排序

  • 显示员工信息,按照department_id的降序排列,salary的升序排列
代码语言:sql
复制
SELECT employee_id,salary,department_id
FROM employees
ORDER BY department_id DESC,salary ASC;
在这里插入图片描述
在这里插入图片描述
  • 可以使用不在SELECT列表中的列排序。
  • 在对多列进行排序的时候,首先排序的第一列必须有相同的列值,才会对第二列进行排序。如果第一列数据中所有值都是唯一的,将不再对第二列进行排序。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 排序数据
    • 1. 排序规则
      • 2. 单列排序
        • 3. 多列排序
        相关产品与服务
        云数据库 SQL Server
        腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档