Transact-SQL 示例
任务需求是这样的,定义一个存储过程可以根据设定的存储过程参数去查询某个表返回可以分页的,参数的功能如下: 1.返回记录集的第n页(@pageNo) 2.每页显示n条记录(@pageSize) 3.筛选条件(@where) 4.排序规则(@orderby) 5.总记录数(@rows) Ok,在拿
任务需求是这样的,香港虚拟主机,定义一个存储过程可以根据设定的存储过程参数去查询某个表返回可以分页的,参数的功能如下:
1.返回记录集的第n页(@pageNo)
2.每页显示n条记录(@pageSize)
3.筛选条件(@where)
4.排序规则(@orderby)
5.总记录数(@rows)
Ok,在拿到需求后,香港服务器,便开始分析。。。这里需要使用到拼接sql字符串变量然后Exec @sql即可,美国空间,但是实践发现。Exec @sql并不能把总记录数传递给外部的@rows OUTPUT参数上,为此stackoverflow一番发现答案。
下面是本人目前的做法:
--定义存储过程
-- 示例过程中使用每个数据库都会自带的系统视图sys.objects作为测试用表
CREATE PROCEDURE dbo.Demo1
@pageNo int = 1,
@pageSize int = 10,
@where nvarchar(1000) = N'',
@orderby nvarchar(1000) = N'name asc',
@rows int OUTPUT
AS
BEGIN
DECLARE @sql nvarchar(max)
SET @sql = N'SELECT @rowsInner = COUNT(1) FROM sys.objects'
IF @where N''
SET @sql = @sql + N' WHERE ' + @where
SET @sql = @sql + N';
SELECT *
FROM (
SELECT ROW_NUMBER() OVER(ORDER BY ' + @orderby + N') RowId,
object_id,
name
FROM
sys.objects '
IF (@where N'')
SET @sql = @sql + N'WHERE ' + @where
SET @sql = @sql + N'
) a
WHERE
a.RowId between (@pageNoInner - 1) * @pageSizeInner + 1 AND @pageNoInner * @pageSizeInner'
--若要调试请撤销如下代码的注释并注释

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

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

熱門話題

在建立虛擬機器時,系統會要求您選擇磁碟類型,您可以選擇固定磁碟或動態磁碟。如果您選擇了固定磁碟,後來意識到需要動態磁碟,或者相反,該怎麼辦?好!你可以把一種轉換成另一種。在這篇文章中,我們將看到如何將VirtualBox固定磁碟轉換為動態磁碟,反之亦然。動態磁碟是一種虛擬硬碟,它最初具有較小的大小,隨著您在虛擬機器中儲存數據,其大小會相應增長。動態磁碟在節省儲存空間方面非常高效,因為它們只佔用所需的主機儲存空間。然而,隨著磁碟容量的擴展,可能會稍微影響電腦的效能。固定磁碟和動態磁碟是虛擬機器中常用的

Excel是否繼續拋出此工作簿包含指向一個或多個外部來源的鏈接,這些外部來源在開啟工作簿時可能會顯示不安全警告訊息?許多用戶報告說,無論何時打開Excel文件都會收到此警告。雖然該警告指示工作簿中存在潛在的惡意鏈接,但即使您已包含受信任的外部來源,也可能會觸發該警告此工作簿包含指向一個或多個可能不安全的外部來源的鏈接如果打開Excel文件時出現警告提示“此工作簿包含指向一個或多個可能不安全的外部來源的連結”,您可以嘗試以下解決方案來解決該問題:檢查工作簿中的外部連結並刪除不受信任的鏈接。使用編輯連結功能

Python函數介紹:exec函數的介紹及範例引言:在Python中,exec是一種內建函數,它用於執行儲存在字串或檔案中的Python程式碼。 exec函數提供了一種動態執行程式碼的方式,使得程式可以在執行時間根據需要產生、修改和執行程式碼。本文將介紹exec函數的使用方法,並給出一些實際的程式碼範例。 exec函式的使用方法:exec函式的基本語法如下圖所示:exec

Go语言的缩进规范及示例Go语言是一种由Google开发的编程语言,它以简洁、清晰的语法著称,其中缩进规范在代码的可读性和美观性方面起着至关重要的作用。本文将介绍Go语言的缩进规范,并通过具体的代码示例进行详细说明。缩进规范在Go语言中,缩进使用制表符(tab)而非空格。每级缩进为一个制表符,通常设置为4个空格的宽度。这样的规范统一了代码风格,使得团队合作编

Oracle中的DECODE函數是一種條件式,常用於在查詢語句中根據不同的條件傳回不同的結果。本文將詳細介紹DECODE函數的語法、用法和範例程式碼。一、DECODE函數語法DECODE(expr,search1,result1[,search2,result2,...,default])expr:要進行比較的表達式或欄位。 search1,

Python函數介紹:isinstance函數的用法和範例Python是一門功能強大的程式語言,提供了許多內建函數,使得程式設計變得更加方便和有效率。其中一個非常有用的內建函數是isinstance()函數。本文將介紹isinstance函數的用法和範例,並提供具體的程式碼範例。 isinstance()函數用來判斷一個物件是否是指定的類別或類型的實例。該函數的語法如下

Python函數介紹:eval函數的功能和範例在Python程式設計中,eval函數是非常有用的一個函數。 eval函數可以將一個字串作為程式碼執行,它的功能非常強大。在本文中,我們將介紹eval函數的詳細功能,以及一些使用範例。一、eval函數的函數eval函數的功能非常簡單,它可以將一個字串作為Python程式碼來執行。這意味著,我們可以將一個字串

Python函數介紹:sorted函數的功能和範例Python是一門非常強大的程式語言,擁有豐富的內建函數和模組。在這個系列文章中,我們將逐一介紹Python常用的函數,並提供對應的範例來幫助讀者更好地理解和應用這些函數。本篇文章將詳細介紹sorted函數的功能和範例。 sorted函數用於對可迭代物件進行排序,並傳回排序後的新列表。可以用於對數字、字
