search
HomeDatabaseOracleHow to query the first 10 records in oracle

In Oracle, you can use the where clause with rownum to query the first ten records. The where clause is used to limit the conditions of the query, and rownum is used to limit the total number of rows returned for the query. The syntax is "select * from table Name where rownum

How to query the first 10 records in oracle

The operating environment of this tutorial: Windows 10 system, Oracle 11g version, Dell G3 computer.

How to query the top 10 records in Oracle

How to query the top 10 records in the table in Oracle?

  select *
  from test
  where rownum <=10

The following is an introduction to rownum

The use of Rownum and row_number() over()

ROWNUM is a pseudo column provided by Oracle starting from 8. It is a SQL The results are numbered, always starting from 1. A common use is to output in pages.

For example,

  SELECT *
  FROM torderdetail a
  WHERE ROWNUM <= 10

This statement is to output the first 10 records. The purpose here is similar to The top of sql sever, but rownum should be said to be more powerful for the output of the specified number range

  SELECT *
  FROM (SELECT a.*, ROWNUM rn
  FROM torderdetail a)
  WHERE rn >= 10 AND rn <= 20

This statement outputs the 10th to 20th records. The reason why rownum rn is used here is to convert rownum into Example, because rownum itself can only use the = comparison can be done.

In practical applications, it is often required to get the most recent records. This requires sorting the records first and then getting rownum

Generally common

  SELECT *
  FROM (SELECT a.*
  FROM torderdetail a
  ORDER BY order_date DESC)
  WHERE ROWNUM <= 10

There has been a discussion in CSDN. Regarding the 10 closest records, someone gave such a statement

  SELECT a.*
  FROM torderdetail a
  WHERE ROWNUM <= 10
  ORDER BY order_date DESC

The reason why such a statement appears is mainly from the perspective of efficiency. The previous statement , it is necessary to scan the entire table and then sort, and then fetch 10 records. The latter statement will not scan the entire table, but will only fetch 10 records. Obviously, the efficiency of the latter statement will be much higher.

Then why is there a dispute? The dispute lies in the order of execution. Should the sorting be performed first to get 10 records, or should the 10 records be taken and then sorted? The results of fetching in the two orders are completely opposite. Sorting first and then fetching 10 records will fetch the 10 most recent records. Fetching 10 records first and then sorting will fetch the earliest 10 records. For this statement, it is generally believed that the execution order is to first fetch 10 records and then sort them. So this statement should be an error. But this is not actually the case. The execution order of this statement is related to the field of order by. If the field of your order by is pk, it is sorted first, and then 10 items are taken (faster than the first statement), and the sorting field When it is not PK, 10 items are taken first and then sorted. At this time, the result is different from the requirements, so the second way of writing must ensure that the result is correct when the sorting field is the primary key.

The analysis function Row_number() over() has been provided since 9I. Its general purpose is similar to rownum.

The general writing method row_number() over(order by order_date desc) generates the same order as the rownum statement, and the efficiency is the same (for the rownum statement that also has order by), so in this case both The usage is the same.

For grouping, taking the latest 10 records cannot be achieved by rownum. At this time, only row_number can be achieved. row_number() over(partition by grouping field order by sorting field) can be achieved after grouping. Number, for example, if you want to get the last 10 order records of each day in the past month

  SELECT *
  FROM (SELECT a.*,
  ROW_NUMBER () OVER (PARTITION BY TRUNC (order_date) ORDER BY order_date DESC)
  rn
  FROM torderdetail a)
  WHERE rn <= 10

Alternative usage of Rownum, sometimes we will encounter this demand, requiring the output of all the days of the month, many people will be troubled, There is no such table in the database, so how can we output all the days in a month? It can be solved with rownum:

  SELECT TRUNC (SYSDATE, &#39;MM&#39;) + ROWNUM - 1
  FROM DUAL
  CONNECT BY ROWNUM <= TO_NUMBER (TO_CHAR (LAST_DAY (SYSDATE), &#39;dd&#39;))

Recommended tutorial: "Oracle Video Tutorial"

The above is the detailed content of How to query the first 10 records in oracle. For more information, please follow other related articles on the PHP Chinese website!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
MySQL vs. Oracle: Understanding Licensing and CostMySQL vs. Oracle: Understanding Licensing and CostMay 03, 2025 am 12:19 AM

MySQL uses GPL and commercial licenses for small and open source projects; Oracle uses commercial licenses for enterprises that require high performance. MySQL's GPL license is free, and commercial licenses require payment; Oracle license fees are calculated based on processors or users, and the cost is relatively high.

Oracle: From Databases to Cloud ServicesOracle: From Databases to Cloud ServicesMay 02, 2025 am 12:05 AM

Oracle's evolution from database to cloud services demonstrates its strong technical strength and market insight. 1. Oracle originated in the 1970s and is famous for its relational database management system, and has launched innovative functions such as PL/SQL. 2. The core of Oracle database is relational model and SQL optimization, which supports multi-tenant architecture. 3. Oracle cloud services provide IaaS, PaaS and SaaS through OCI, and AutonomousDatabase performs well. 4. When using Oracle, you need to pay attention to the complex licensing model, performance optimization and data security issues in cloud migration.

Oracle and MySQL: Exploring Data Management ApproachesOracle and MySQL: Exploring Data Management ApproachesMay 01, 2025 am 12:13 AM

Oracle is suitable for enterprise-level applications that require high performance and complex queries, and MySQL is suitable for web applications that are rapidly developed and deployed. 1. Oracle supports complex transaction processing and high availability, suitable for financial and large ERP systems. 2.MySQL emphasizes ease of use and open source support, and is widely used in small and medium-sized enterprises and Internet projects.

MySQL vs. Oracle: A Look at the User ExperienceMySQL vs. Oracle: A Look at the User ExperienceApr 30, 2025 am 12:12 AM

The differences in user experience between MySQL and Oracle are mainly reflected in: 1. MySQL is simple and easy to use, suitable for quick access and high flexibility scenarios; 2. Oracle has powerful functions, suitable for scenarios that require enterprise-level support. MySQL's open source and free features attract startups and individual developers, while Oracle's complex features and tools meet the needs of large enterprises.

MySQL and Oracle: Exploring Performance and ScalabilityMySQL and Oracle: Exploring Performance and ScalabilityApr 29, 2025 am 12:12 AM

The difference between MySQL and Oracle in performance and scalability is: 1. MySQL performs better on small to medium-sized data sets, suitable for fast scaling and efficient reading and writing; 2. Oracle has more advantages in handling large data sets and complex queries, suitable for high availability and complex business logic. MySQL extends through master-slave replication and sharding technologies, while Oracle achieves high availability and scalability through RAC.

What Oracle Software Does: Key Functions and FeaturesWhat Oracle Software Does: Key Functions and FeaturesApr 28, 2025 am 12:08 AM

Key features of Oracle software include multi-tenant architecture, advanced analytics and data mining, real-time application clustering (RAC), and automated management and monitoring. 1) A multi-tenant architecture allows for the management of multiple independent databases in one database instance, simplifying management and reducing costs. 2) Advanced analytics and data mining tools such as Oracle Advanced Analytics and OracleDataMining help extract insights from data. 3) Real-time application cluster (RAC) provides high availability and scalability, improving system fault tolerance and performance. 4) Automated management and monitoring tools such as Oracle EnterpriseManager (OEM) to automate daily maintenance tasks and monitor numbers in real time

Oracle's Impact: Data Management and BeyondOracle's Impact: Data Management and BeyondApr 27, 2025 am 12:11 AM

Oracle has a profound impact in the fields of data management and enterprise applications. Its database is known for its reliability, scalability and security, and is widely used in industries such as finance, medical care and government. Oracle's influence has also expanded to middleware and cloud computing fields such as WebLogicServer and OracleCloudInfrastructure (OCI), providing innovative solutions. Despite the competition in the open source database and cloud computing market, Oracle maintains its leading position through continuous innovation.

Oracle: Exploring the Company's Mission and ValueOracle: Exploring the Company's Mission and ValueApr 26, 2025 am 12:06 AM

Oracle's mission is to "help people see the value of data", and its core values ​​include: 1) Customer first, 2) Integrity, 3) Innovation, and 4) Teamwork. These values ​​guide Oracle's strategic decision-making and business innovation in the market.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version

MantisBT

MantisBT

Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use