首頁 資料庫 mysql教程 (转)SqlServer2005高效分页sql查询语句汇总

(转)SqlServer2005高效分页sql查询语句汇总

Jun 07, 2016 pm 03:13 PM
sql 分頁 查詢 語句 高效率

sqlserver2005不支持关键字limit ,所以它的分页sql 查询 语句 将不能用mysql的方式进行,幸好sqlserver2005提供了top,rownumber等关键字,这样就能通过这几个关键字实现分页。 下面是本人在网上查阅到的几种 查询 脚本的写法: 几种sqlserver2005 高效 分

sqlserver2005不支持关键字limit ,所以它的分页sql查询语句将不能用mysql的方式进行,幸好sqlserver2005提供了top,rownumber等关键字,这样就能通过这几个关键字实现分页。

下面是本人在网上查阅到的几种查询脚本的写法:

几种sqlserver2005高效分页sql查询语句
top方案:
???sql code

select top 10 * from table1
???where id not in(select top 开始的位置 id from table1)

max:
????sql code

select top 10 * from table1
????where id>(select max(id)
????from (select top 开始位置 id from table1order by id)tt)

row:
? ? sql code

select *
from (
????select row_number()over(order by tempcolumn)temprownumber,*
????from (select top 开始位置+10 tempcolumn=0,* from table1)t
)tt
where temprownumber>开始位置
3种分页方式,分别是max方案,top方案,row方案

效率:
第1:row
第2:max
第3:top

缺点:
max:必须用户编写复杂sql,不支持非唯一列排序
top:必须用户编写复杂sql,不支持复合主键
row:不支持sqlserver2000

测试数据:
共320万条数据,每页显示10条数据,分别测试了2万页、15万页和32万页。

页码,top方案,max方案,row方案
2万,60ms,46ms,33ms
15万,453ms,343ms,310ms
32万,953ms,720ms,686ms


是一种通过程序拼接sql语句的分页方案,
用户提过的sql语句不需要编写复杂的sql逻辑

诺用户提供sql如下
sql code
select * from table1

?

从第5条开始,查询5条,处理后sql变为
sql code
select *
from (
????select row_number()over(order by tempcolumn)temprownumber,*
????from (select top 10 tempcolumn=0,* from table1)t
)tt
where temprownumber>5

?

这是什么意思呢?分解一下

首先将用户输入的sql语句转稍稍修改
在select后添加top 开始位置+条数变成
再外加一列tempcolum,变成这样
sql code
select top 20 tempcolumn=0,* from clazz


嵌套一层,这样便可查询出行号
???刚才那个列就是用来这里order by用的
(也不知道sqlserver的row_number函数为什么必须要order by)
sql code
select row_number()over(order by tempcolumn)temprownumber,*
from (修改过的查询)t


再套一层,过滤掉行号小于开始位置的行
sql code
select * from (第二层)tt
where temprownumber>10

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

熱門話題

Java教學
1664
14
CakePHP 教程
1423
52
Laravel 教程
1318
25
PHP教程
1269
29
C# 教程
1248
24
Hibernate 框架中 HQL 和 SQL 的差異是什麼? Hibernate 框架中 HQL 和 SQL 的差異是什麼? Apr 17, 2024 pm 02:57 PM

HQL和SQL在Hibernate框架中進行比較:HQL(1.物件導向語法,2.資料庫無關的查詢,3.類型安全),而SQL直接操作資料庫(1.與資料庫無關的標準,2.可執行複雜查詢和資料操作)。

12306怎麼查詢歷史購票紀錄 查看歷史購票紀錄的方法 12306怎麼查詢歷史購票紀錄 查看歷史購票紀錄的方法 Mar 28, 2024 pm 03:11 PM

12306訂票app下載最新版是一款大家非常滿意的出行購票軟體,想去哪裡就去那裡非常方便,軟體內提供的票源非常多,只需要通過實名認證就能在線購票,所有用戶的出行車票機票都可以輕鬆買到,享受不同的優惠折扣。還能提前開啟預約搶票,預約飯店、專車接送都是可以的,有了它想去哪裡就去那裡一鍵購票,出行更加簡單方便,讓大家的出行體驗更舒服,現在小編在線詳細為12306用戶帶來查看歷史購票記錄的方法。  1.打開鐵路12306,點擊右下角我的,點擊我的訂單  2.在訂單頁面點擊已支付。  3.在已支付頁

學信網如何查詢自己的學歷 學信網如何查詢自己的學歷 Mar 28, 2024 pm 04:31 PM

學信網如何查詢自己的學歷?在學信網中是可以查詢到自己的學歷,很多用戶都不知道如何在學信網中查詢到自己的學歷,接下來就是小編為用戶帶來的學信網查詢自己學歷方法圖文教程,感興趣的用戶快來一起看看吧!學信網使用教程學信網如何查詢自己的學歷一、學信網入口:https://www.chsi.com.cn/二、網站查詢:第一步:點選上方學信網位址,進入首頁點選【學歷查詢】;第二步:在最新的網頁中點選如下圖箭頭所示的【查詢】;第三步:之後在新頁面點選【的登陸學信檔案】;第四步:在登陸頁面輸入資料點選【登陸】;

深入了解Go語言的功能與特點 深入了解Go語言的功能與特點 Mar 21, 2024 pm 05:42 PM

Go語言的功能與特色Go語言,又稱Golang,是一種由Google開發的開源程式語言,設計初衷是為了提升程式效率和可維護性。自誕生以來,Go語言在程式設計領域展現了獨特的魅力,並受到了廣泛的關注和認可。本文將深入探討Go語言的功能與特點,並透過具體的程式碼範例來展示其強大之處。原生並發支援Go語言天生支援並發編程,透過goroutine和channel的機制實現

C盤空間告急! 5種高效率清理方法大揭密! C盤空間告急! 5種高效率清理方法大揭密! Mar 26, 2024 am 08:51 AM

C盤空間告急! 5種高效率清理方法大揭密!在使用電腦的過程中,不少用戶會遇到C盤空間告急的情況,尤其是在儲存或安裝大量檔案後,C碟的可用空間會迅速減少,進而影響電腦效能和運作速度。此時,對C盤進行清理是十分必要的。那麼,該如何有效率地清理C盤呢?接下來,本文將揭示5種高效率的清理方法,幫助您輕鬆解決C盤空間抱怨的問題。一、清理臨時檔案臨時檔案是電腦在運作時產生的一些暫

PHP數組分頁的最佳實作方式 PHP數組分頁的最佳實作方式 May 04, 2024 pm 02:39 PM

PHP陣列分頁有兩種最常見的方式:使用array_slice()函數:計算要跳過的元素數量,然後提取指定範圍的元素。使用內建迭代器:實作Iterator接口,rewind()、key()、current()、next()和valid()方法用於遍歷指定範圍內的元素。

比較Python和C++學習成本:哪個比較值得投入? 比較Python和C++學習成本:哪個比較值得投入? Mar 25, 2024 pm 10:24 PM

Python和C++是兩種流行的程式語言,各有其優點和缺點。對於希望學習程式設計的人來說,選擇學習Python還是C++往往是一個重要決定。本文將探討Python和C++的學習成本,並討論哪種語言較值得投入時間與精力。首先,讓我們從Python開始。 Python是一種高階、解釋型的程式語言,以其簡單易學、程式碼清晰、語法簡潔等特色而聞名。相較於C++,Python

Go語言中SQL的基本概念及用法解析 Go語言中SQL的基本概念及用法解析 Mar 27, 2024 pm 05:30 PM

Go語言中SQL的基本概念及用法解析SQL(StructuredQueryLanguage)是一種專門用來管理和操作關聯式資料庫的語言。在Go語言中,我們通常使用SQL來執行資料庫操作,例如查詢資料、插入資料、更新資料和刪除資料等。本文將介紹Go語言中SQL的基本概念及用法,並附帶具體的程式碼範例。 1.連接資料庫在Go語言中,我們可以使用第三方函式庫來連接數據

See all articles