当前位置: 首页 > news >正文

【Oracle11g SQL详解】ORDER BY 子句的排序规则与应用

ORDER BY 子句的排序规则与应用

在 Oracle 11g 中,ORDER BY 子句用于对查询结果进行排序。通过使用 ORDER BY,可以使返回的数据按照指定的列或表达式以升序或降序排列,便于数据的分析和呈现。本文将详细讲解 ORDER BY 子句的规则及其常见应用。


一、ORDER BY 子句的基本语法
SELECT 列名1, 列名2, ...
FROM 表名
[WHERE 条件]
ORDER BY 列名 [ASC|DESC], 列名2 [ASC|DESC];

说明:

  • ORDER BY:指定排序列或表达式。
  • ASC(默认):升序排列,从小到大。
  • DESC:降序排列,从大到小。
  • 可以根据多个列进行排序,按列顺序依次排序。

二、ORDER BY 子句的排序规则
  1. 按单列排序
    • 默认情况下,ORDER BY 按升序排列。
    • 如果需要降序排列,必须显式指定 DESC

示例:

SELECT employee_id, salary 
FROM employees
ORDER BY salary ASC;  -- 按薪资升序排列
SELECT employee_id, salary 
FROM employees
ORDER BY salary DESC; -- 按薪资降序排列

  1. 按多列排序
    • 先按第一列排序,如果第一列值相同,则按第二列排序,以此类推。

示例:

SELECT employee_id, department_id, salary 
FROM employees
ORDER BY department_id ASC, salary DESC;

说明:

  • department_id 升序排列。
  • department_id 相同的情况下,按 salary 降序排列。

  1. 按表达式排序
    • ORDER BY 支持基于表达式的排序,如计算列或函数结果。

示例:

SELECT employee_id, first_name, last_name, salary * 12 AS annual_salary
FROM employees
ORDER BY annual_salary DESC;

说明: 按员工年薪(salary * 12)从高到低排序。


  1. 按列别名排序
    • 可以使用 SELECT 中定义的列别名进行排序。

示例:

SELECT employee_id, first_name || ' ' || last_name AS full_name, salary 
FROM employees
ORDER BY full_name ASC;

说明: 按员工全名(full_name)字母顺序升序排列。


  1. 按列位置排序
    • 直接使用列的位置编号排序,从 SELECT 子句中列的顺序开始。

示例:

SELECT employee_id, department_id, salary 
FROM employees
ORDER BY 2 ASC, 3 DESC;

说明:

  • 2 表示按 department_id 升序排列。
  • 3 表示按 salary 降序排列。

三、ORDER BY 与 NULL 值的排序

在 Oracle 中,NULL 值在排序时具有以下特点:

  • 默认情况下,升序排列时,NULL 值排在最后;
  • 降序排列时,NULL 值排在最前。

如果需要修改这一行为,可以使用 NULLS FIRSTNULLS LAST 明确指定。

示例:

SELECT employee_id, salary 
FROM employees
ORDER BY salary ASC NULLS FIRST; -- NULL 值排在最前
SELECT employee_id, salary 
FROM employees
ORDER BY salary DESC NULLS LAST; -- NULL 值排在最后

四、ORDER BY 子句的高级用法
  1. 按日期排序
SELECT employee_id, hire_date 
FROM employees
ORDER BY hire_date DESC;

说明: 按雇佣日期从最近到最早排序。

  1. 按条件排序
SELECT employee_id, salary, CASE WHEN salary >= 10000 THEN '高薪' WHEN salary >= 5000 THEN '中等薪资' ELSE '低薪' END AS salary_level
FROM employees
ORDER BY salary_level ASC, salary DESC;

说明:

  • 先按自定义薪资级别排序(高薪 > 中等薪资 > 低薪)。
  • 在相同薪资级别内,再按实际薪资降序排列。
  1. 限制查询结果的排序行数
    结合 ROWNUMFETCH 子句,按排序结果筛选出前 N 条记录。

示例:返回薪资最高的前 5 名员工:

SELECT employee_id, salary 
FROM employees
ORDER BY salary DESC
FETCH FIRST 5 ROWS ONLY;

五、性能优化建议
  1. 使用索引

    • 对排序列建立索引,尤其是对大表或排序操作频繁的列。
  2. 避免过多排序列

    • 排序列越多,排序计算量越大,尽量减少不必要的排序列。
  3. 减少复杂表达式

    • 如果排序基于复杂表达式,建议在查询之前先将表达式计算好的结果存储为列。

六、练习示例
  1. 查询所有员工信息,按部门编号升序排列:
SELECT * FROM employees
ORDER BY department_id ASC;
  1. 查询所有员工的姓名和薪资,按薪资降序排列,薪资相同的按姓名升序排列:
SELECT first_name, last_name, salary 
FROM employees
ORDER BY salary DESC, first_name ASC;
  1. 查询所有部门信息,按部门名称的字母倒序排列:
SELECT department_id, department_name 
FROM departments
ORDER BY department_name DESC;

七、小结

ORDER BY 子句是 SQL 查询中重要的工具,用于对数据进行排序以满足各种分析需求。掌握其语法、规则和优化方法,可以显著提升查询的实用性和效率。

相关文章:

【Oracle11g SQL详解】ORDER BY 子句的排序规则与应用

ORDER BY 子句的排序规则与应用 在 Oracle 11g 中,ORDER BY 子句用于对查询结果进行排序。通过使用 ORDER BY,可以使返回的数据按照指定的列或表达式以升序或降序排列,便于数据的分析和呈现。本文将详细讲解 ORDER BY 子句的规则及其常见应用…...

YOLO系列论文综述(从YOLOv1到YOLOv11)【第15篇(完结):讨论和未来展望】

总结 0 前言1 YOLO与人工通用智能(AGI)2 YOLO作为“能够行动的神经网络”3 具身人工智能(EAI)4 边缘设备上的YOLO5 评估统计指标的挑战6 YOLO与环境影响 YOLO系列博文: 【第1篇:概述物体检测算法发展史、YO…...

Java设计模式 —— 【创建型模式】原型模式(浅拷贝、深拷贝)详解

文章目录 前言原型模式一、浅拷贝1、案例2、引用数据类型 二、深拷贝1、重写clone()方法2、序列化 总结 前言 先看一下传统的对象克隆方式: 原型类: public class Student {private String name;public Student(String name) {this.name name;}publi…...

SciAssess——评估大语言模型在科学文献处理中关于模型的记忆、理解和分析能力的基准

概述 大规模语言模型(如 Llama、Gemini 和 GPT-4)的最新进展因其卓越的自然语言理解和生成能力而备受关注。对这些模型进行评估对于确定其局限性和潜力以及促进进一步的技术进步非常重要。为此,人们提出了一些特定的基准来评估大规模语言模型…...

SQLModel与FastAPI结合:构建用户增删改查接口

SQLModel简介 SQLModel是一个现代化的Python库,旨在简化与数据库的交互。它结合了Pydantic和SQLAlchemy的优势,使得定义数据模型、进行数据验证和与数据库交互变得更加直观和高效。SQLModel由FastAPI的创始人Sebastin Ramrez开发,专为与FastA…...

【RISC-V CPU debug 专栏 2.3 -- Run Control】

文章目录 Run ControlHart 运行控制状态位状态信号操作流程时间与实现注意事项Run Control 在 RISC-V 调试架构中,运行控制模块通过管理多个状态位来对硬件线程(harts)的执行进行调节和控制。这些状态位帮助调试器请求暂停或恢复 harts,并在 hart 复位时进行控制。以下是运…...

探索 IntelliJ IDEA 中 Spring Boot 运行配置

前言 IntelliJ IDEA 作为一款功能强大的集成开发环境(IDE),为 Spring Boot 应用提供了丰富的运行配置选项,定义了如何在 IntelliJ IDEA 中运行 Spring Boot 应用程序,当从主类文件运行应用程序时,IDE 将创建…...

三除数枚举

给你一个整数 n 。如果 n 恰好有三个正除数 ,返回 true ;否则,返回 false 。 如果存在整数 k ,满足 n k * m ,那么整数 m 就是 n 的一个 除数 。 输入:n 4 输出:true 解释:4 有三…...

【051】基于51单片机温度计【Proteus仿真+Keil程序+报告+原理图】

☆、设计硬件组成:51单片机最小系统DS18B20温度传感器LCD1602液晶显示按键设置蜂鸣器LED灯。 1、本设计采用STC89C51/52、AT89C51/52、AT89S51/52作为主控芯片; 2、采用DS18B20温度传感器测量温度,并且通过LCD1602实时显示温度;…...

[Java]微服务之服务保护

雪崩问题 微服务调用链路中的某个服务故障,引起整个链路中的所有微服务都不可用,这就是雪崩 雪崩问题产生的原因是什么? 微服务相互调用,服务提供者出现故障或阻塞。服务调用者没有做好异常处理,导致自身故障。调用链中的所有服…...

自动驾驶目标检测融合全貌

1、early fusion 早期融合,特点用到几何空间转换3d到2d或者2d到3d的转换,用像素找点云或者用点云找像素。 2、deep fusion 深度融合,也是特征级别融合,也叫多模态融合,如bevfusion范式 3、late fusion 晚融合&#x…...

消息框(Message Box)的测试方法和测试用例

我来帮你了解消息框(Message Box)的测试方法和测试用例的编写。 我已经创建了一个测试用例示例,让我为你解释消息框测试的主要方面: 测试维度: 功能性测试:验证消息框的基本功能是否正常样式测试:确认不同类型消息框…...

Ubuntu 包管理

APT&dpkg 查看已安装包 查看所有已经安装的包 dpkg -l 查找包 apt search <package_name>搜索软件包列表&#xff0c;找到与搜索关键字匹配的包 dpkg与grep结合查找特定的包 dpkg -s <package>&#xff1a;查看某个安装包的详细信息 安装包 apt安装命令 更新…...

[Ubuntu] linux之Ubuntu18.04的下载及在虚拟机中详细安装过程(附有下载链接)

前言 ubuntu 链接&#xff1a;https://pan.quark.cn/s/283509d0d36e 提取码&#xff1a;dfT1 链接失效&#xff08;可能被官方和谐&#xff09;可评论或私信我重发 下载压缩包后解压 &#xff01;&#xff01;安装路径不要有中文 下载后解压得到.iso文件&#xff0c;不要放在…...

ffmpeg安装(windows)

ffmpeg安装-windows 前言ffmpeg安装路径安装说明 前言 ffmpeg的安装也是开箱即用的,并没有小码哥说的那么难 ffmpeg安装路径 这就下载好了! 安装说明 将上面的bin目录加入到环境变量,然后在cmd中测试一下: C:\Users\12114\Desktop\test\TaskmgrPlayer\x64\Debug>ffmpe…...

服务器数据恢复—raid6阵列硬盘被误重组为raid5阵列的数据恢复案例

服务器存储数据恢复环境&#xff1a; 存储中有一组由12块硬盘组建的RAID6阵列&#xff0c;上层linux操作系统EXT3文件系统&#xff0c;该存储划分3个LUN。 服务器存储故障&分析&#xff1a; 存储中RAID6阵列不可用。为了抢救数据&#xff0c;运维人员使用原始RAID中的部分…...

linux内核编译启动总结

linux kernel 编译 升级汇总 写在前面内核编译获取kernel代码开始前的准备工作 编译过程1\.解压与净化将下载好的linux内核解压至/usr/src 2\. 得到源代码后,将其净化3\. 配置要进行编译的内核4.编译内核. &#xff08;15分钟&#xff09;5.编译模块.方法1:方法2&#xff1a; 6…...

Android Studio的AI工具插件使用介绍

Android Studio的AI工具插件使用介绍 一、前言 Android Studio 的 AI 工具插件具有诸多重要作用&#xff0c;以下是一些常见的方面&#xff1a; 代码生成与自动补全 代码优化与重构 代码解读 学习与知识获取 智能搜索与资源推荐实际使用中可以添加注释&#xff0c;解读某段代…...

本地部署 WireGuard 无需公网 IP 实现异地组网

WireGuard 是一个高性能、极简且易于配置的开源虚拟组网协议。使用路由侠内网穿透使其相互通讯。 第一步&#xff0c;服务端&#xff08;假设为公司电脑&#xff09;和客户端&#xff08;假设为公司外的电脑&#xff09;安装部署 WireGuard 1&#xff0c;点此下载&#xff08;…...

asyncio.ensure_future 与 asyncio.create_task:Python异步编程中的选择

asyncio.ensure_future 与 asyncio.create_task&#xff1a;Python异步编程中的选择 引言asyncio.ensure_futureasyncio.create_task两者的区别参数接受范围任务调度的保证代码可读性 哪个更好&#xff1f;使用asyncio.create_task使用asyncio.ensure_future 结论参考 引言 在…...

CTF之密码学(密码特征分析)

一.MD5,sha1,HMAC,NTLM 1.MD5&#xff1a;MD5一般由32/16位的数字(0-9)和字母(a-f)组成的字符串 2.sha1&#xff1a;这种加密的密文特征跟MD5差不多&#xff0c;只不过位数是40&#xff08;sha256&#xff1a;64位&#xff1b;sha512:128位&#xff09; 3.HMAC&#xff1a;这…...

JVM调优篇之JVM基础入门AND字节码文件解读

目录 Java程序编译class文件内容常量池附录-访问标识表附录-常量池类型列表 Java程序编译 Java文件通过编译成class文件后&#xff0c;通过JVM虚拟机解释字节码文件转为操作系统执行的二进制码运行。 规范 Java虚拟机有自己的一套规范&#xff0c;遵循这套规范&#xff0c;任…...

EXCEL截取某一列从第一个字符开始到特定字符结束的字符串到新的一列

使用EXCEL中的公式进行特定截取 假设列A是一组产品的编码&#xff0c;我们需要的数据是“-”之前的字段。 我们需要在B1单元格输入公式“LEFT(A1,SEARCH("-",A1)-1)”然后选中B1至B4单元格&#xff0c;按“CTRLD”向下填充&#xff0c;就可以得出其它几行“-”之前的…...

数据库期末复习题库

1. Mysql日志功能有哪些? 记录日常操作和错误信息&#xff0c;以便了解Mysql数据库的运行情况&#xff0c;日常操作&#xff0c;错误信息和进行相关的优化。 2. 数据库有哪些备份方法 完全备份&#xff1a;全部都备份一遍表备份&#xff1a;只提取数据库中的数据&#xff0…...

私有库gitea安装

一 gitea是什么 Gitea是一款自助Git服务&#xff0c;简单来说&#xff0c;就是可以一个私有的github。 搭建很容易。 Gitea依赖于Git。 类似Gitea的还有GitHub、Gitee、GitLab等。 以下是安装步骤。 二 安装sqilite 参考&#xff1a; 在windows上安装sqlite 三 安装git…...

关于最近win11不能使用ie,而不能使用考试客户端的解决方法

弄ie的那个我感觉是非常难的&#xff0c;所以我的是另一种的方法 下载360浏览器&#xff08;不是360全家桶&#xff09;360安全浏览器-全面保护上网安全&#xff0c;4亿用户共同选择&#xff08;上面的是官网&#xff0c;不要下载错了&#xff0c;还有安装界面注意不要勾选一下…...

深度学习之Mask-R-CNN

1.1 Mask-RCNN 的网络结构示意图 其中黑色部分为原来的Faster-RCNN&#xff0c;红色部分为在Faster网络上的修改&#xff1a;    1&#xff09;将ROI Pooling层替换成了ROIAlign&#xff1b;    2&#xff09;添加并列的FCN层&#xff08;Mask层&#xff09;&#xff1b;  …...

css包含块

包含块 出现 在css中一些属性的计算可能超出你的预料&#xff0c;在普遍情况下会认为定位属性和百分比的宽高是根据父元素计算的&#xff0c;但是准确来说他们都是根据元素所在的包含块来计算的&#xff0c;所以掌握包含块的知识是非常关键的。 内容 在CSS中&#xff0c;“…...

混沌工程/混沌测试/云原生测试/云平台测试

背景 私有云/公有云/混合云等具有复杂&#xff0c;分布式&#xff0c;环境多样性等特点&#xff0c;许多特殊场景引发的线上问题很难被有效发现。所以需要引入混沌工程&#xff0c;建立对系统抵御生产环境中失控条件的能力以及信心&#xff0c;提高系统面对未知风险得能力。 …...

研发设计数字化:PLM、PDM、ERP介绍及其区别

一、产品全生命周期管理的定义 1.1 产品全生命周期&#xff08;PLM&#xff09;发展背景 目前&#xff0c;数字化设计与制造的技术&#xff08;如CAX、DFX等&#xff09;已经在产品开发中得到广泛应用&#xff0c;而各种企业和产品管理软件&#xff08;如ERP、SCM、PDM、CRM等…...

做视频网站收入/推广引流吸引人的标题

g的编译选项介绍&#xff1a; -WI的理解&#xff0c;gcc的-WI,xxx选项似乎是在 gcc 中使用 ld 链接选项时候的编译器选项 -L: “链接” 的时候&#xff0c;去找的链接库的目录 - rpath&#xff08;或 - R &#xff0c;这似乎是一个内容&#xff09;&#xff0c;意思是“运行…...

怎样创建网站域名平台/小程序推广50个方法

一、为什么要有Unsfae、我们为什么要了解这个类1. java通常的代码无法直接使用操作底层的硬件&#xff0c;为了使java具备该能力&#xff0c;增加了Unsafe类2.java的并发包中底层大量的使用这个类的功能&#xff0c;了解这个类有助于了解java 并发包&#xff0c;理解为什么并发…...

怎么免费做一个网站/目前主流搜索引擎是哪种

正常的求LIS的方法是用dp来做&#xff0c;时间复杂度为O(n^2),但是面对一些题目的时候这个复杂度就有点高了&#xff0c;就去学了一下nlogn的解法。主要运用到了二分查找&#xff0c;stl里面的lower_bound 也可以。 upper_bound&#xff08;i&#xff09; 返回的是键值为i的元素…...

做装修公司网站/一台电脑赚钱的门路

目录.NET Core实用技巧(一)如何将EF Core生成的SQL语句显示在控制台中前言笔者最近在开发和维护一个.NET Core项目&#xff0c;其中使用几个非常有意思的.NET Core相关的扩展&#xff0c;在此总结整理一下。EF Core性能调优如果你的项目中使用了EF Core, 且正在处于性能调优阶段…...

离石古楼角网站建设/友情链接如何交换

为什么80%的码农都做不了架构师&#xff1f;>>> 各个数据库like写法&#xff1a; oracle数据库&#xff1a; SELECT * FROM user WHERE name like CONCAT(%,#{name},%) 或 : SELECT * FROM user WHERE name like %||#{name}||% SQLServer数据库&#xff1a; SELECT…...

沈阳网站搜索排名/百度广告登录入口

最后贴一张小米官方拆机零件汇总图片&#xff1a;软件篇&#xff1a;小米路由器的系统是在开源OpenWRT的基础上进行了定制。界面交互更加友好。经过几天的试用&#xff0c;《假装是极客》感受最深的是&#xff0c;小米路由的APP与小米系列硬件已经深度集成&#xff0c;如果是米…...