sql 2000 分页存储过程

简介:


复制代码
set  ANSI_NULLS  ON
set  QUOTED_IDENTIFIER  ON
go

--  [SelectBase] 1,1,'( select j.*,u.P_Name from Job j left join Users u on j.UserID=u.ID) T','Flag=0'
             alter   procedure   [ SelectBase ]
            
@PageIndex                 int
            
@PageSize                 int
            
@TableName      nvarchar ( 2000 ), 
            
@Where          nvarchar ( 2000 ) = ''  
            
as  
            
Declare   @rowcount            int  
            
Declare   @intStart            int  
            
Declare   @intEnd           int  
            
declare   @Column1   varchar ( 32 -- 第一列名称
             Declare   @SQl   nvarchar ( 2000 ),  @WhereR   nvarchar ( 1000 ),  @OrderBy   nvarchar ( 1000
            
set   @rowcount = 0  
            
set  nocount  on  
            
if   @Where <> ''  
            
begin  
            
set   @Where = '  and  ' + @Where  
            
end  
            
if   CHARINDEX ( ' order by ' @Where ) > 0  
            
begin  
            
set   @WhereR = substring ( @Where 1 CHARINDEX ( ' order by ' , @Where ) - 1 )     -- 取得条件 
             set   @OrderBy = substring ( @Where CHARINDEX ( ' order by ' , @Where ),  Len ( @Where ))     -- 取得排序方式(order by 字段 方式) 
             end  
            
else  
            
begin  
            
set   @WhereR = @Where  
            
set   @OrderBy = '  order by id asc '  
            
end  
            
set   @SQl = ' SELECT @rowcount=count(*) from  ' + cast ( @TableName   as   nvarchar ( 2000 )) + '  where 1=1  ' + @WhereR  
            
            
exec  sp_executeSql  @SQl ,N ' @rowcount int output ' , @rowcount  output 
            
if   @PageIndex = 0   and   @PageSize = 0      -- 不进行分页,查询所有数据列表 
             begin  
            
set   @SQl = ' SELECT * from  ' + cast ( @TableName   as   nvarchar ( 2000 )) + '  where 1=1  ' + @Where  
            
end  
            
else      -- 进行分页查询数据列表 
             begin  
            
set   @intStart = ( @PageIndex - 1 ) * @PageSize + 1
            
set   @intEnd = @intStart + @PageSize - 1  
            
declare   @PKName   nvarchar ( 50 )
            
if ( len ( @TableName ) > 50 )
            
begin
                
Set   @Column1 = ' ID '
            
end
            
else
            
begin
            
set   @Column1 = col_name ( object_id ( @tableName ), 1 -- 设置第一列名称
             end
            
set   @SQl = ' Create table #tem(Row int identity(1,1) not null,joinRow int)  '   
            
set   @SQl = @SQl + ' insert #tem(joinRow) select  ' + @Column1 + '  from  ' + @TableName   + '  where 1=1  ' + @WhereR  
            
set   @SQl = @SQl + '  select * from  ' + @TableName + '  right join #tem  on  ' + @Column1 + ' =#tem.joinRow  '   
            
set   @SQl = @SQl + '  where #tem.Row between  ' + cast ( @intStart   as   varchar ) + '  and  ' + cast ( @intEnd   as   varchar
            
end  
            
-- PRINT @SQl
             exec  sp_executeSql  @SQl  
            
return   @rowcount  
            
set  nocount  off  
复制代码
相关文章
|
9月前
|
存储 SQL Perl
PL/SQL编程—分页功能(存储过程)
PL/SQL编程—分页功能(存储过程)
79 0
|
存储 SQL 数据处理
Sql Server 分页存储过程
分页存储过程一: --/*-----存储过程 分页处理 孙伟 2005-03-28创建 -------*/ --/*----- 对数据进行了2分处理使查询前半部分数据与查询后半部分数据性能相同 -------*/ --/*-----存储过程 分页处理 孙伟 2005-04-21修改 添加Distinct查询功能-------*/ --/*-----存储过程 分页处理 孙伟 20
1033 0
|
SQL 存储 索引
原创:SQL Server的通用分页存储过程,未使用游标,速度更快!
使用SQL Server时,分页处理一直是个比较棘手的问题 正常情况下,SQL Server服务器上会对使用频率大的Table建立合适的索引 这样能大幅度的提高数据库本身的数据检索速度,建立索引的方法就不细说了   如果需要返回大量数据,从几百行到几万行,甚至几十万行数据 这时会发现响应速...
892 0
|
SQL 存储 Go
SQL SERVER的分页存储过程
CREATE PROCEDURE sp_page @tb varchar(50), --表名 @col varchar(50), --按该列来进行分页 @coltype int, --@col列的类型,0-数字类型,1-字符类型,2-日期时间类型 @orderby bit, --排序,0-顺序,1-...
774 0
|
27天前
|
SQL 算法 数据库
【数据库SQL server】关系数据库标准语言SQL之数据查询
【数据库SQL server】关系数据库标准语言SQL之数据查询
46 0
|
27天前
|
SQL 算法 数据库
【数据库SQL server】关系数据库标准语言SQL之视图
【数据库SQL server】关系数据库标准语言SQL之视图
36 0