全面的儲存過程 測試可用
USE [Studentnew]
GO
/******
分頁,呼叫例子如下
exec dbo.cs_GetPageOfRecords 2,1,'*','a','1=1','id',1,'id'
輸入引數:每頁2條,第1頁,得到所有欄位顯示出來,表a,查詢條件1=1
根據id降序排列,主鍵id
******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
--建立儲存過程
ALTER PROCEDURE [dbo].[cs_GetPageOfRecords]
@pageSize int = 20, --分頁大小
@currentPage int , --第幾頁
@columns varchar(1000) = '*', --需要得到的欄位
@tableName varchar(100), --需要查詢的表
@condition varchar(1000) = '', --查詢條件, 不用加where關鍵字
@ascColumn varchar(100) = '', --排序的欄位名 (即 order by column asc/desc)
@bitOrderType bit = 0, --排序的型別 (0為升序,1為降序)
@pkColumn varchar(50) = '' --主鍵名稱
AS
BEGIN --儲存過程開始
DECLARE @strTemp varchar(300)
DECLARE @strSql varchar(5000) --該儲存過程最後執行的語句
DECLARE @strOrderType varchar(1000) --排序型別語句 (order by column asc或者order by column desc)
BEGIN
IF @bitOrderType = 1 --降序
BEGIN
SET @strOrderType = ' ORDER BY '+@ascColumn+' DESC'
SET @strTemp = '<(SELECT min'
END
ELSE --升序
BEGIN
SET @strOrderType = ' ORDER BY '+@ascColumn+' ASC'
SET @strTemp = '>(SELECT max'
END
IF @currentPage = 1 --第一頁
BEGIN
IF @condition != ''
SET @strSql = 'SELECT TOP '+STR(@pageSize)+' '+@columns+' FROM '+@tableName+
' WHERE '+@condition+@strOrderType
ELSE
SET @strSql = 'SELECT TOP '+STR(@pageSize)+' '+@columns+' FROM '+@tableName+@strOrderType
END
ELSE -- 其他頁
BEGIN
IF @condition !=''
SET @strSql = 'SELECT TOP '+STR(@pageSize)+' '+@columns+' FROM '+@tableName+
' WHERE '+@condition+' AND '+@pkColumn+@strTemp+'('+@pkColumn+')'+' FROM (SELECT TOP '+STR((@currentPage-1)*@pageSize)+
' '+@pkColumn+' FROM '+@tableName +'where'+@condition+@strOrderType+') AS TabTemp)'+@strOrderType
ELSE
SET @strSql = 'SELECT TOP '+STR(@pageSize)+' '+@columns+' FROM '+@tableName+
' WHERE '+@pkColumn+@strTemp+'('+@pkColumn+')'+' FROM (SELECT TOP '+STR((@currentPage-1)*@pageSize)+' '+@pkColumn+
' FROM '+@tableName+@strOrderType+') AS TabTemp)'+@strOrderType
END
END
EXEC (@strSql)
END
GO
/******
分頁,呼叫例子如下
exec dbo.cs_GetPageOfRecords 2,1,'*','a','1=1','id',1,'id'
輸入引數:每頁2條,第1頁,得到所有欄位顯示出來,表a,查詢條件1=1
根據id降序排列,主鍵id
******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
--建立儲存過程
ALTER PROCEDURE [dbo].[cs_GetPageOfRecords]
@pageSize int = 20, --分頁大小
@currentPage int , --第幾頁
@columns varchar(1000) = '*', --需要得到的欄位
@tableName varchar(100), --需要查詢的表
@condition varchar(1000) = '', --查詢條件, 不用加where關鍵字
@ascColumn varchar(100) = '', --排序的欄位名 (即 order by column asc/desc)
@bitOrderType bit = 0, --排序的型別 (0為升序,1為降序)
@pkColumn varchar(50) = '' --主鍵名稱
AS
BEGIN --儲存過程開始
DECLARE @strTemp varchar(300)
DECLARE @strSql varchar(5000) --該儲存過程最後執行的語句
DECLARE @strOrderType varchar(1000) --排序型別語句 (order by column asc或者order by column desc)
BEGIN
IF @bitOrderType = 1 --降序
BEGIN
SET @strOrderType = ' ORDER BY '+@ascColumn+' DESC'
SET @strTemp = '<(SELECT min'
END
ELSE --升序
BEGIN
SET @strOrderType = ' ORDER BY '+@ascColumn+' ASC'
SET @strTemp = '>(SELECT max'
END
IF @currentPage = 1 --第一頁
BEGIN
IF @condition != ''
SET @strSql = 'SELECT TOP '+STR(@pageSize)+' '+@columns+' FROM '+@tableName+
' WHERE '+@condition+@strOrderType
ELSE
SET @strSql = 'SELECT TOP '+STR(@pageSize)+' '+@columns+' FROM '+@tableName+@strOrderType
END
ELSE -- 其他頁
BEGIN
IF @condition !=''
SET @strSql = 'SELECT TOP '+STR(@pageSize)+' '+@columns+' FROM '+@tableName+
' WHERE '+@condition+' AND '+@pkColumn+@strTemp+'('+@pkColumn+')'+' FROM (SELECT TOP '+STR((@currentPage-1)*@pageSize)+
' '+@pkColumn+' FROM '+@tableName +'where'+@condition+@strOrderType+') AS TabTemp)'+@strOrderType
ELSE
SET @strSql = 'SELECT TOP '+STR(@pageSize)+' '+@columns+' FROM '+@tableName+
' WHERE '+@pkColumn+@strTemp+'('+@pkColumn+')'+' FROM (SELECT TOP '+STR((@currentPage-1)*@pageSize)+' '+@pkColumn+
' FROM '+@tableName+@strOrderType+') AS TabTemp)'+@strOrderType
END
END
EXEC (@strSql)
END
相關文章
- [原創]儲存過程效能測試儲存過程
- ORACLE儲存過程中建立子過程的測試!Oracle儲存過程
- 我的測試儲存過程程式碼儲存過程
- 使用dbms_profiler測試儲存過程效能儲存過程
- 儲存過程在主從庫上的測試儲存過程
- oracle 匿名儲存過程插入大量測試資料Oracle儲存過程
- mysql儲存過程小試牛刀MySql儲存過程
- MySQL儲存過程詳解 mysql 儲存過程MySql儲存過程
- 儲存過程儲存過程
- 在sqlplus互動環境下測試儲存過程SQL儲存過程
- SQL 儲存過程裡呼叫另一個儲存過程SQL儲存過程
- MySQL儲存過程詳解 mysql 儲存過程linkMySql儲存過程
- Oracle儲存過程乾貨(一):儲存過程基礎Oracle儲存過程
- 儲存過程與儲存函式儲存過程儲存函式
- Oracle儲存過程Oracle儲存過程
- 使用儲存過程儲存過程
- sybase儲存過程儲存過程
- java儲存過程Java儲存過程
- 管理儲存過程儲存過程
- 呼叫儲存過程儲存過程
- mysql 儲存過程MySql儲存過程
- SQLSERVER儲存過程SQLServer儲存過程
- 實戰儲存過程排程過程儲存過程
- 在儲存過程A中呼叫儲存過程B的結果儲存過程
- 從sybase的儲存過程轉向oracle的儲存過程儲存過程Oracle
- 基於儲存過程的百萬級測試資料自動生成儲存過程
- 回顧專案測試全過程,測試如何回答 “測完了嗎?”
- MySql儲存過程—2、第一個MySql儲存過程的建立MySql儲存過程
- 把自編儲存過程設定為系統儲存過程儲存過程
- oracle儲存過程plsql_sp_多個out引數測試語法Oracle儲存過程SQL
- 儲存過程 傳 datatable儲存過程
- 儲存過程——遊標儲存過程
- Oracle儲存過程-1Oracle儲存過程
- mysql儲存過程整理MySql儲存過程
- JAVA儲存過程(轉)Java儲存過程
- JdbcTemplate調儲存過程JDBC儲存過程
- Winform呼叫儲存過程ORM儲存過程
- oracle的儲存過程Oracle儲存過程