搜尋
首頁資料庫mysql教程oracle分页查询sql原理与语句

很多朋友使用多了mysql limit进行分页到了oracle中就不知道如何写分页了,其实oracle分页与mssql分页很像的,下面我来给大家介绍oracle分页语句。

很多朋友使用多了mysql limit进行分页到了oracle中就不知道如何写分页了,其实oracle分页与mssql分页很像的,下面我来给大家介绍oracle分页语句。

最简单使用方法

 代码如下 复制代码

t2.*
from (select rownum r,t1.* from youtable t1 where rownum) t2
where t2.r>?

小于最大的,大于最小的,就是你需要的条数.如果你取40-50条之间的

查询格式:

 代码如下 复制代码

SELECT * FROM
(
SELECT A.*, ROWNUM RN
FROM (SELECT * FROM TABLE_NAME) A
WHERE ROWNUM )
WHERE RN >= 21

其中最内层的查询SELECT * FROM TABLE_NAME表示不进行翻页的原始查询语句。ROWNUM = 21控制分页查询的每页的范围。
上面给出的这个分页查询语句,在大多数情况拥有较高的效率。分页的目的就是控制输出结果集大小,将结果尽快的返回。在上面的分页查询语句中,这种考虑主要体现在WHERE ROWNUM 选择第21到40条记录存在两种方法,一种是上面例子中展示的在查询的第二层通过ROWNUM

 代码如下 复制代码

SELECT * FROM

(
SELECT A.*, ROWNUM RN
FROM (SELECT * FROM TABLE_NAME) A
)
WHERE RN BETWEEN 21 AND 40

后来发现数据越大就查询越慢了,后来得出一些测试结果分享给大家。

--1:无ORDER BY排序的写法。(效率最高)
--(经过测试,此方法成本最低,只嵌套一层,速度最快!即使查询的数据量再大,也几乎不受影响,速度依然!)

 代码如下 复制代码
SELECT *
  FROM (Select ROWNUM AS ROWNO, T.*
           from k_task T
          where Flight_date between to_date('20060501', 'yyyymmdd') and
                to_date('20060731', 'yyyymmdd')
            AND ROWNUM WHERE TABLE_ALIAS.ROWNO >= 10;

--2:有ORDER BY排序的写法。(效率最高)
--(经过测试,此方法随着查询范围的扩大,速度也会越来越慢哦!)

 代码如下 复制代码
SELECT *
  FROM (SELECT TT.*, ROWNUM AS ROWNO
           FROM (Select t.*
                    from k_task T
                   where flight_date between to_date('20060501', 'yyyymmdd') and
                         to_date('20060531', 'yyyymmdd')
                   ORDER BY FACT_UP_TIME, flight_no) TT
          WHERE ROWNUM where TABLE_ALIAS.rowno >= 10;

--3:无ORDER BY排序的写法。(建议使用方法1代替)
--(此方法随着查询数据量的扩张,速度会越来越慢哦!)

 代码如下 复制代码
SELECT *
  FROM (Select ROWNUM AS ROWNO, T.*
           from k_task T
          where Flight_date between to_date('20060501', 'yyyymmdd') and
                to_date('20060731', 'yyyymmdd')) TABLE_ALIAS
WHERE TABLE_ALIAS.ROWNO    AND TABLE_ALIAS.ROWNO >= 10;
--TABLE_ALIAS.ROWNO  between 10 and 100;

--4:有ORDER BY排序的写法.(建议使用方法2代替)
--(此方法随着查询范围的扩大,速度会越来越慢哦!)

 代码如下 复制代码
SELECT *
  FROM (SELECT TT.*, ROWNUM AS ROWNO
           FROM (Select *
                    from k_task T
                   where flight_date between to_date('20060501', 'yyyymmdd') and
                         to_date('20060531', 'yyyymmdd')
                   ORDER BY FACT_UP_TIME, flight_no) TT) TABLE_ALIAS
where TABLE_ALIAS.rowno BETWEEN 10 AND 20;


--5另类语法。(有ORDER BY写法)
--(语法风格与传统的SQL语法不同,不方便阅读与理解,为规范与统一标准,不推荐使用。)

 代码如下 复制代码
With partdata as(
  SELECT ROWNUM AS ROWNO, TT.*  FROM (Select *
                  from k_task T
                 where flight_date between to_date('20060501', 'yyyymmdd') and
                       to_date('20060531', 'yyyymmdd')
                 ORDER BY FACT_UP_TIME, flight_no) TT
   WHERE ROWNUM     Select * from partdata where rowno >= 10;

--6另类语法 。(无ORDER BY写法)

 代码如下 复制代码

With partdata as(
  Select ROWNUM AS ROWNO, T.*
    From K_task T
   where Flight_date between to_date('20060501', 'yyyymmdd') and
         To_date('20060531', 'yyyymmdd')
     AND ROWNUM     Select * from partdata where Rowno >= 10;   

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
如何使用PHP数据库连接实现分页查询如何使用PHP数据库连接实现分页查询Sep 08, 2023 pm 02:28 PM

如何使用PHP数据库连接实现分页查询在开发web应用中,常常会涉及到对数据库进行查询并进行分页显示的需求。PHP作为一种常用的服务端脚本语言,具备强大的数据库连接功能,可以很方便地实现分页查询。本文将详细介绍如何使用PHP数据库连接实现分页查询,并附上相应的代码示例。准备数据库在开始之前,我们需要准备一个数据库,包含要查询的数据。这里以MySQL数据库为例,

PHP和PDO: 如何进行分页查询和显示数据PHP和PDO: 如何进行分页查询和显示数据Jul 29, 2023 pm 04:10 PM

PHP和PDO:如何进行分页查询和显示数据在开发Web应用程序时,分页查询和显示数据是一个非常常见的需求。通过分页,我们可以一次显示一定数量的数据,提高页面加载速度和用户体验。在PHP中,使用PHP数据对象(PDO)库可以轻松实现分页查询和显示数据的功能。本文将介绍如何在PHP中使用PDO进行分页查询和显示数据,并提供相应的代码示例。一、创建数据库和数据表

如何使用Go语言创建高性能的MySQL数据分页查询如何使用Go语言创建高性能的MySQL数据分页查询Jun 17, 2023 am 09:09 AM

随着互联网的快速发展,数据处理已经成为了企业应用开发的一项重要技能。在许多应用程序中,MySQL数据库经常是最常用的数据存储之一。在MySQL中,数据分页查询是一项常见的数据检索操作。本文将介绍如何使用Go语言实现高性能的MySQL数据分页查询。一、什么是数据分页查询?数据分页查询是一种常用的数据检索技术,它可以让用户在一页上只浏览少量的数据而不必一次性加载

PHP和Oracle数据库的分页查询技巧PHP和Oracle数据库的分页查询技巧Jul 11, 2023 pm 11:09 PM

PHP和Oracle数据库的分页查询技巧在开发一个动态网页时,如果需要展示大量数据,就需要进行分页查询。分页查询是一种将数据划分为更小的页面,以便用户能够轻松地浏览和导航的技术。在本文中,我们将讨论如何使用PHP和Oracle数据库实现分页查询,并提供相关的代码示例。一、准备工作在开始之前,我们需要确保我们已经安装和配置好了PHP和Oracle数据库。如果还

PHP如何使用MongoDB进行分页查询PHP如何使用MongoDB进行分页查询Jul 07, 2023 pm 09:28 PM

PHP如何使用MongoDB进行分页查询概述:MongoDB是一个非关系型数据库,常用于存储大量的文档数据,而PHP是一种流行的服务器端脚本语言。在本文中,将介绍如何使用PHP来连接MongoDB,并且实现分页查询的功能。步骤一:安装MongoDB扩展在PHP中与MongoDB进行交互需要安装MongoDB的扩展。可以通过以下命令来安装MongoDB扩展:p

如何在ThinkPHP6中使用Mysql进行分页查询如何在ThinkPHP6中使用Mysql进行分页查询Jun 20, 2023 pm 02:01 PM

随着互联网的快速发展,Web应用程序的开发也越来越复杂。而分页查询是Web应用程序中常见的功能之一。ThinkPHP6是一个web框架,可以帮助开发人员快速开发应用程序。在本文中,我们将讨论如何在ThinkPHP6中使用MySQL进行分页查询。首先,我们需要在ThinkPHP6中创建数据库。在MySQL中创建数据库的语句如下:CREATEDATABASE

MySql的分页查询:如何处理大数据库分页的性能问题MySql的分页查询:如何处理大数据库分页的性能问题Jun 15, 2023 pm 03:28 PM

在现代应用程序中,大部分的数据都需要分页显示。当应用程序需要处理大量数据的时候,这就会给服务器和数据库造成压力,导致查询耗时变长。Mysql是目前最受欢迎的关系型数据库之一,本文将讨论如何优化Mysql分页查询的性能问题。分页原理在开始优化之前,我们必须先了解分页原理。分页查询的主要原理是将表数据分成若干个分页,然后逐个分页地查询数据。例如,如果我们需要在一

PHP开发中如何处理大规模数据库查询PHP开发中如何处理大规模数据库查询Oct 08, 2023 am 09:22 AM

PHP开发中如何处理大规模数据库查询在PHP开发过程中,处理大规模数据库查询是一个常见的挑战。当应用程序需要查询的数据量大到无法一次性加载到内存中时,需要采取一些策略来提高查询效率,并且确保应用程序的性能不会受到过多的影响。下面将介绍几个处理大规模数据库查询的常用技巧和代码示例:分页查询当查询结果数量很大时,将结果分成若干页进行显示可以避免一次性加载过多数据

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前By尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
4 週前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境