Oracle 中 FETCH FIRST ... ROWS WITH TIES子句

在 Oracle 数据库中,FETCH FIRST ... ROWS WITH TIES 是一个子句,它用于与 ORDER BY 子句结合,以获取与第一组(根据排序条件)具有相同排序值的所有行。这通常用于在结果集中包括那些与最前面的几行具有相同排序值的行。

FETCH FIRST ... ROWS WITH TIES 是一个子句,Oracle 12c 及更高版本中可用

下面是一个示例查询包含员工和他们工资的表:

sql 复制代码
HR@orcl> select employee_id,first_name,last_name,salary from employees ORDER BY salary DESC;

EMPLOYEE_ID FIRST_NAME           LAST_NAME                     SALARY
----------- -------------------- ------------------------- ----------
        100 Steven               King                           24000
        101 Neena                Kochhar                        17000
        102 Lex                  De Haan                        17000
        145 John                 Russell                        14000
        146 Karen                Partners                       13500
        201 Michael              Hartstein                      13000
        108 Nancy                Greenberg                      12008
        205 Shelley              Higgins                        12008
        147 Alberto              Errazuriz                      12000
        168 Lisa                 Ozer                           11500
        114 Den                  Raphaely                       11000

例如,假设你有一个包含员工和他们工资的表,并且你想获取工资最高的前两个员工。但是,如果有多个员工具有相同的最高工资,你可能也想包括他们。这时,你可以使用 FETCH FIRST ... ROWS WITH TIES。

sql 复制代码
HR@orcl> select employee_id,first_name,last_name,salary from employees ORDER BY salary DESC fetch first 2 rows with ties;

EMPLOYEE_ID FIRST_NAME           LAST_NAME                     SALARY
----------- -------------------- ------------------------- ----------
        100 Steven               King                           24000
        101 Neena                Kochhar                        17000
        102 Lex                  De Haan                        17000

在这个查询中:

  • ORDER BY salary DESC 会将员工按工资从高到低排序。

  • FETCH FIRST 2 ROWS WITH TIES 会获取前两名(即工资最高的两名),但如果有多名员工的工资与这两名相同,那么这些员工也会被包括在结果集中。

这个子句在 Oracle 12c 及更高版本中可用。如果你使用的是较早版本的 Oracle,那么你可能需要使用不同的方法(如子查询或窗口函数)来实现相同的效果。

相关推荐
小光学长2 分钟前
基于ssm的书法学习交流系统25ki07v1(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
java·开发语言·数据库·学习·ssm
sygydxfwd6 分钟前
TwinCAT 3配合MySQL数据库实现ms级数据存储
数据库·mysql
IT成长日记6 分钟前
国产数据库DM8实战手册:静默安装部署全教程
数据库·dm8·国产数据库·静默安装·部署教程
HAPPY酷12 分钟前
Ubuntu 中如何启用 root 账户?—— 从 “su: 认证失败” 到成功切换 root 的完整指南
服务器·数据库·ubuntu
熊哈哈O_o18 分钟前
基于代价模型的复杂查询连接条件下推技术实践——以金仓数据库为例
数据库
Elastic 中国社区官方博客43 分钟前
Elasticsearch Serverless 的无状态架构
大数据·数据库·elasticsearch·搜索引擎·云原生·架构·serverless
happymaker06261 小时前
JDBC(MySQL)——DAY02
android·数据库·mysql
十月南城1 小时前
实时数据平台的价值链——数据采集、加工、存储、查询与消费的协同效应与ROI评估
数据库·数据仓库·hive·hadoop·spark
有梦想的小何1 小时前
从结算需求出发:基于库存日快照与分区的结算报表的Java实践
java·数据库·mysql
Yungoal1 小时前
SQL基础0
数据库·sql