oracle怎么获取行,在oracle中如何实现SELECT TOP N取得前几行记录

在sql server中可以通过SELECT TOP N来取得想要结果的前几行的信息。

但是在oracle中必须借助伪列rownum来完成

一个查询语句在取得结果集后,伪列rownum就会从1开始,从上往下依次递增。rownum是对结果集的编序排列。例如下表:

SQL> select id,name,salary,rownum from wages;

ID NAME           SALARY     ROWNUM

---------- ---------- ---------- ----------

1 zhangsan         3600          1

2 lisi             2500          2

3 wangwu           5000          3

4 zhaoliu          4500          4

5 xiaoming         2000          5

所以取得该表的前三行,为

SQL> select id,name,salary,rownum from wages where rownum<=3;

ID NAME           SALARY     ROWNUM

---------- ---------- ---------- ----------

1 zhangsan         3600          1

2 lisi             2500          2

3 wangwu           5000          3

但是,这样直接取表的前N行一般是无意义的。rownum一般是和order by搭配使用,通过排序,再取得自己想要的前几行。

但是在使用rownum的时候要注意,使用排序后,返回的结果顺序是进行了排序,但是rownum还是和原来的一样,没有随着排序而改变。

原因:ROWNUM的编排在排序之前就产生了。

SQL> select id,name,salary,rownum from wages order by salary;

ID NAME           SALARY     ROWNUM

---------- ---------- ---------- ----------

5 xiaoming         2000          5

2 lisi             2500          2

1 zhangsan         3600          1

4 zhaoliu          4500          4

3 wangwu           5000          3

所以此时使用要取工资最高的前三名,就发生了错误的结果

SQL> select id,name,salary,rownum from wages where rownum<=3 order by salary;

ID NAME           SALARY     ROWNUM

---------- ---------- ---------- ----------

2 lisi             2500          2

1 zhangsan         3600          1

3 wangwu           5000          3

但是,我们可以需要嵌套一层子查询来抽取排序好的数据

SQL>  select id,name,salary,rownum from (select * from wages order by salary);

ID NAME           SALARY     ROWNUM

---------- ---------- ---------- ----------

5 xiaoming         2000          1

2 lisi             2500          2

1 zhangsan         3600          3

4 zhaoliu          4500          4

3 wangwu           5000          5

此时,rownum已经发生了变化,在通过外部查询指定范围,就可以得到想要的正确结果

SQL> select id,name,salary,rownum from (select * from wages order by salary) where rownum<=3;

ID NAME           SALARY     ROWNUM

---------- ---------- ---------- ----------

5 xiaoming         2000          1

2 lisi             2500          2

1 zhangsan         3600          3

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/31386161/viewspace-2128815/,如需转载,请注明出处,否则将追究法律责任。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/392217.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

图片管理程序(Java)

图片管理程序 gitee完整代码下载 github完整代码下载 华南农业大学课程设计作品&#xff08;99分&#xff09; 问题描述 题目目的是编写一个能够对数字像片进行管理的应用程序。 程序能够显示的图片格式包括,.JPG、.JPEG、.GIF、.PNG、和.BMP。 图像文件尺寸,要求能够处理从…

气流与路易吉,阿戈,MLFlow,KubeFlow

任务编排工具和工作流程 (Task orchestration tools and workflows) Recently there’s been an explosion of new tools for orchestrating task- and data workflows (sometimes referred to as “MLOps”). The quantity of these tools can make it hard to choose which o…

移动WEB开发之JS内置touch事件[转]

iOS上的Safari也支持click 和mouseover等传统的交互事件&#xff0c;只是不推荐在iOS的浏览器应用上使用click和mouseover&#xff0c;因为这两个事件是为了支持鼠标点击而设计 出来的。Click事件在iOS上会有半秒左右的延迟&#xff0c;原因是iOS要highlight接收到click的eleme…

编写代码的软件用什么编写的_如何通过像编写代码一样克服对编写的恐惧

编写代码的软件用什么编写的by Chris Rowe通过克里斯罗 How often do you get the fear? What do I mean by fear? How about the knot I got in my stomach just before I plunged out of plane on a parachute jump? It’s more than the brain logically planning to av…

快速学习一个新的模块

1、模块名.__doc__查看函数简介&#xff0c;为了便于查看&#xff0c;采用print&#xff08;模块名.__doc__&#xff09;打印出来&#xff0c;这样的格式便于查看。 2、采用内置方法dir()查看模块的变量、函数、类等等&#xff1b;采用"模块名.__all__"查看模块中提供…

php 公钥格式转换,如何把OpenSSH公钥转换成OpenSSL格式

《如何把OpenSSH公钥转换成OpenSSL格式》要点&#xff1a;本文介绍了如何把OpenSSH公钥转换成OpenSSL格式&#xff0c;希望对您有用。如果有疑问&#xff0c;可以联系我们。首先看看OpenSSL工具的简单使用方法,我们以rsa加密算法为例生成一个私钥&#xff1a;openssl genrsa -o…

模拟操作系统(Java)

gitee完整代码下载 github完整代码下载 一、 需求分析 模拟一个采用多道程序设计方法的单用户操作系统&#xff0c;该操作系统包括进程管理、存储管理、设备管理、文件管理和用户接口四部分。预计程序所能达到的功能&#xff1a; 进程管理模拟&#xff1a;实现操作系统进程管…

数据库面试复习_数据科学面试复习

数据库面试复习大面试前先刷新 (REFRESH BEFORE THE BIG INTERVIEW) 介绍 (Introduction) I crafted this study guide from multiple sources to make it as comprehensive as possible. This guide helped me prepare for both the technical and behavioral aspects of the …

hibernate缓存

&#xff08;转自&#xff1a;http://www.cnblogs.com/java-class/p/6108175.html&#xff09; 阅读目录 1. 为什么要用 Hibernate 缓存&#xff1f;2. 项目实战3. Hibernate 缓存原理回到顶部1. 为什么要用 Hibernate 缓存&#xff1f; Hibernate是一个持久层框架&#xff0c;…

oracle 连接greenplum,Oracle通过DBLINK访问GreenPlum

为多个数据库之间的整合和迁移做POC&#xff0c;尝试使用Oracle Gateway和Heterogeneous Service来中转访问&#xff0c;测试过好多次&#xff0c;最终发现只有在32位的Oracle当中才能成功配置。 配置环境如下&#xff1a; Windows 2003 32bit 或 Windows 2008 64bit Oracle10G…

如何使用React和Redux前端创建Rails项目

by Mark Hopson马克霍普森(Mark Hopson) 如何使用React和Redux前端(加上Typescript&#xff01;)创建Rails项目 (How to create a Rails project with a React and Redux front-end (plus Typescript!)) 在Rails项目中使用React和Redux设置单页Javascript App的完整指南。 (A …

分布与并行计算—用任务管理器画CPU正弦曲线(Java)

class drawSin implements Runnable{Overridepublic void run() {final double SPLIT 0.01;// 角度的分割final int COUNT (int) (2 / SPLIT);// 2PI分割的次数&#xff0c;也就是2/0.01个&#xff0c;正好是一周final double PI Math.PI;final int interval 100;// 时间间…

Rails文件上传file_field报错Encoding::UndefinedConversionError

服务器用的是ubuntu12 64bit&#xff0c;环境是ruby1.9.3rails3mysql&#xff0c;测试是在windows2003上。 上传一个【.gitconfig】文件&#xff0c;没有问题&#xff0c;上传【新浪微博数据挖掘.pdf】报错&#xff0c;上传【back.jpg】报错。 下面是两段信息&#xff0c;是从【…

好久不来这里写东西了.

我正准备离开学校去实现自己的目标,很清楚自己在学校的... ...做共享程序员,就不得不考虑些商业上的东西,自己要吃饭啊!我想我是该好好的处理一下这二者的关系. 转载于:https://www.cnblogs.com/wangxiang/archive/2007/01/01/609714.html

Asp.net mvc中使用配置Unity

第一步&#xff1a;添加unity.mvc 第二步&#xff1a;在添加之后会在app_start中生成UnityConfig.cs&#xff0c;UnityMvcActivator.cs 第三步&#xff1a;使用 第四步&#xff1a;效果展示 转载于:https://www.cnblogs.com/WJ--NET/p/7117839.html

顶级数据恢复_顶级R数据科学图书馆

顶级数据恢复Data science is the discipline of making data useful数据科学是使数据有用的学科 When we talk about the top programming language for Data Science, we often find Python to be the best fit for the topic. Sure, Python is undoubtedly an excellent cho…

xp系统oracle数据库,Oracle10g 数据库的安装基于windowsXP

Oracle的安装一、首先去官网下载自身系统相对应的数据库软件http://www.oracle.com/cn/index.htmlOracle软件本身是免费的&#xff0c;个人用途完全没关系&#xff0c;商业用途并被发现才会被Oracle所要求收费&#xff0c;收费买的不是软件&#xff0c;而是授权。何谓授权&…

了解React Native中的不同JavaScript环境

by Khoa Pham通过Khoa Pham 了解React Native中的不同JavaScript环境 (Get to know different JavaScript environments in React Native) React Native can be very easy to get started with, and then at some point problems occur and we need to dive deep into it.Reac…

分布与并行计算—生命游戏(Java)

生命游戏其实是一个零玩家游戏&#xff0c;它包括一个二维矩形世界&#xff0c;这个世界中的每个方格居住着一个活着的或死了的细胞。一个细胞在下一个时刻生死取决于相邻八个方格中活着的或死了的细胞的数量。如果相邻方格活着的细胞数量过多&#xff0c;这个细胞会因为资源匮…

正确认识 Vista 激活期限

当我们在安装 Vista 时&#xff0c;可以不输入序列号进行安装&#xff0c;这和以往的操作系统安装有所不同&#xff0c;我们不必再为安装系统时找不到我们的序列号标签而发愁。如果不输入序列号而继续安装系统&#xff0c;那么系统将提示我们有30天的激活期限&#xff01;这里的…