Rumah pangkalan data tutorial mysql mssqlserver存储过程分页

mssqlserver存储过程分页

Jun 07, 2016 pm 05:49 PM

下面分享一个网友写的mssqlserver存储过程分页有需要的朋友可参考参考。

 代码如下 复制代码

USE [BeyondDB]
GO
/****** Object:  StoredProcedure [dbo].[Y_Paging]    Script Date: 02/22/2013 14:53:26 ******/
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
ALTER proc [dbo].[Y_Paging]
(
    @TableName VARCHAR(max)=null,     --表名          
    @FieldList VARCHAR(max)=null,    --显示列名,如果是全部字段则为*          
    @PrimaryKey VARCHAR(max)=null,    --单一主键或唯一值键          
    @Where NVARCHAR(max)=null,        --查询条件 不含'where'字符,如id>10 and len(userid)>9          
    @Order VARCHAR(max)=null,        --排序 不含'order by'字符,如id asc,userid desc,必须指定asc或desc

            
    @SortType INT=null,               --排序规则 1:正序asc 2:倒序desc 3:多列排序方法          
    @RecorderCount INT=null,          --记录总数 0:会返回总记录          
    @PageSize INT=null,               --每页输出的记录数          
    @PageIndex INT=null,              --当前页数      
    @Keyword varchar(max)=null,       --关键字
    @FieldOne varchar(max)=null,       --字段1
    @FieldTwo varchar(max)=null,       --字段2
    @TotalCount INT OUTPUT,      --记返回总记录          
    @TotalPageCount INT OUTPUT   --返回总页数         
)
as
begin
 
    DECLARE @sql NVARCHAR(max);
    DECLARE @totalSql NVARCHAR(max);
     
          
     
    if(@Keyword is not null and @Keyword !='')
    begin
        if  ISNULL(@FieldOne,'') != ''
         set @Order=@Order+' , (case when charindex('''+replace(@Keyword,' ',''','+@FieldOne+')>0 then

1 else 0 end)+(case when charindex(''')+''','+@FieldOne+')>0 then 1 else 0 end) '
        if  ISNULL(@FieldOne,'') != ''
        set @Order=@Order+' , (case when charindex('''+replace(@Keyword,' ',''','+@FieldTwo+')>0 then 1

else 0 end)+(case when charindex(''')+''','+@FieldTwo+')>0 then 1 else 0 end) '
        end
     
    if(@SortType is not null and @SortType=1)
        set @Order=@Order+' asc '
    if(@SortType is not null and @SortType=2)
        set @Order=@Order+' desc '
 
    SET @sql = ' WITH LIST AS
                 (   
                    SELECT  ' + @FieldList + ',ROW_NUMBER() OVER (ORDER BY ' + @Order + ') as RowNumber
                    FROM ' + @TableName + ' 
                    WHERE 1=1 ' + @Where + '
                     
                 ) 
                 SELECT * FROM LIST WHERE RowNumber BETWEEN ' + STR(@PageIndex+1) + ' AND ' + STR

(@PageIndex + @PageSize)                    
                 
    set @totalSql = ' SELECT  @TOTALCOUNT=COUNT(*) FROM ' + @TableName + ' WHERE 1=1 ' + @Where    
                          
    print(@Sql)
    EXEC(@Sql)                     
    --EXEC sp_executesql  @totalSql,N'
    --                          @ID uniqueidentifier,
                --              @StatusList varchar(max),
                --              @BeginTime datetime,
                --              @EndTime datetime,
                --              @TitleOrNo varchar(max),
                --              @Excutor  uniqueidentifier,
                --              @Assignor uniqueidentifier,
    --                            @TotalCount int output
    --                            ',
    --                            @ID  ,
                --              @StatusList  ,
                --              @BeginTime  ,
                --              @EndTime ,
                --              @TitleOrNo ,
                --              @Excutor,
                --              @Assignor,
    --                            @TotalCount output
end
 
--调用实例
USE [BeyondDB]
GO
 
DECLARE @return_value int,
        @TotalCount int,
        @TotalPageCount int
 
EXEC    @return_value = [dbo].[Y_Paging]
        @TableName = N'Account',
        @FieldList = N'*',
        @PrimaryKey = N'id',
        @Where = N' and 1=1',
        @Order = N' CreateTime ',
        @SortType =2,
        @PageSize = 5,
        @PageIndex = 0,
        @RecorderCount = null,
        @Keyword = N'1',
        @FieldOne = N'Accountname',
        @FieldTwo = N'accountid',
        @TotalCount = @TotalCount OUTPUT,
        @TotalPageCount = @TotalPageCount OUTPUT
 
SELECT  @TotalCount as N'@TotalCount',
        @TotalPageCount as N'@TotalPageCount'
 
SELECT  'Return Value' = @return_value
 
GO

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Repo: Cara menghidupkan semula rakan sepasukan
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Repo: Cara menghidupkan semula rakan sepasukan
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Tag artikel panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Kurangkan penggunaan memori MySQL di Docker Kurangkan penggunaan memori MySQL di Docker Mar 04, 2025 pm 03:52 PM

Kurangkan penggunaan memori MySQL di Docker

Bagaimana anda mengubah jadual di MySQL menggunakan pernyataan Alter Table? Bagaimana anda mengubah jadual di MySQL menggunakan pernyataan Alter Table? Mar 19, 2025 pm 03:51 PM

Bagaimana anda mengubah jadual di MySQL menggunakan pernyataan Alter Table?

Cara menyelesaikan masalah MySQL tidak dapat membuka perpustakaan bersama Cara menyelesaikan masalah MySQL tidak dapat membuka perpustakaan bersama Mar 04, 2025 pm 04:01 PM

Cara menyelesaikan masalah MySQL tidak dapat membuka perpustakaan bersama

Apa itu SQLite? Gambaran Keseluruhan Komprehensif Apa itu SQLite? Gambaran Keseluruhan Komprehensif Mar 04, 2025 pm 03:55 PM

Apa itu SQLite? Gambaran Keseluruhan Komprehensif

Jalankan MySQL di Linux (dengan/tanpa bekas podman dengan phpmyadmin) Jalankan MySQL di Linux (dengan/tanpa bekas podman dengan phpmyadmin) Mar 04, 2025 pm 03:54 PM

Jalankan MySQL di Linux (dengan/tanpa bekas podman dengan phpmyadmin)

Menjalankan Pelbagai Versi MySQL di MacOS: Panduan Langkah demi Langkah Menjalankan Pelbagai Versi MySQL di MacOS: Panduan Langkah demi Langkah Mar 04, 2025 pm 03:49 PM

Menjalankan Pelbagai Versi MySQL di MacOS: Panduan Langkah demi Langkah

Apakah beberapa alat GUI MySQL yang popular (mis., MySQL Workbench, phpmyadmin)? Apakah beberapa alat GUI MySQL yang popular (mis., MySQL Workbench, phpmyadmin)? Mar 21, 2025 pm 06:28 PM

Apakah beberapa alat GUI MySQL yang popular (mis., MySQL Workbench, phpmyadmin)?

Bagaimana saya mengkonfigurasi penyulitan SSL/TLS untuk sambungan MySQL? Bagaimana saya mengkonfigurasi penyulitan SSL/TLS untuk sambungan MySQL? Mar 18, 2025 pm 12:01 PM

Bagaimana saya mengkonfigurasi penyulitan SSL/TLS untuk sambungan MySQL?

See all articles