一个是PAGESIZE
一个是SQL语句注意!!SQL语句是任意的 多表的。SQL语句是任意的SQL语句是任意的SQL语句是任意的多表的。多表的。多表的。多表的。多表的。
不是说是一个表的。。不传字段不传字段不传字段不传字段不传字段不传字段不传字段不传字段不传字段搞定100全部送上。

解决方案 »

  1.   

    -- 存储过程临时表分页查询数据
    create procedure PageGetTemp
    @pagesize int = 10,
    @pagecurrent int = 1
    as
    set nocount on;
    declare @pagerows int
    declare @strSql nvarchar(1000)
    declare @tempstr nvarchar(1000)
    declare @orderstr nvarchar(100)
    declare @pagesums int
    begin
    if @pagesize < 1
    begin
    set @pagesize = 100
    print  @pagesize
    end if @pagecurrent < 1
    begin
    set @pagecurrent = 1
    print @pagecurrent
    end-- 取得总记录数13700185575|13700143573
    delete from temp_phone where phone in (select phone from temp_phone tp where exists (select black_phone from black_list bl where tp.phone = bl.black_phone)) // 这句对你来说没用select @pagerows = count(*) from temp_phone // 取总记录set @pagesums = @pagerows / @pagesize
    if @pagerows % @pagesize != 0
    begin
    set @pagesums = @pagesums + 1
    endif @pagesums >= @pagecurrent
    begin
    if @pagerows < @pagesize
    begin
    set @pagesize = @pagerows
    set @pagecurrent = 1
    end
    endset @strSql = 'select phone from (select ROW_NUMBER() over (order by phone) as rowNum, phone from temp_phone) as b where rowNum > ' + str((@pagecurrent-1) * @pagesize) + ' and rowNum<=(' + str(@pagecurrent*@pagesize) + ' )'; // 只需将这条sql语句重新拆分组合一下,就是你要的结果了end
    exec sp_executesql @strSql你可以在这个的基础上 稍微改一改就行
      

  2.   

    set ANSI_NULLS ON
    set QUOTED_IDENTIFIER ON
    goALTER PROC [dbo].[PROCE_PageView2000]
    (
    @tbname     nvarchar(100),               --要分页显示的表名
    @FieldKey   nvarchar(1000),      --用于定位记录的主键(惟一键)字段,可以是逗号分隔的多个字段
    @PageCurrent int=1,               --要显示的页码
    @PageSize   int=10,                --每页的大小(记录数)
    @FieldShow nvarchar(1000)='',      --以逗号分隔的要显示的字段列表,如果不指定,则显示所有字段
    @FieldOrder nvarchar(1000)='',      --以逗号分隔的排序字段列表,可以指定在字段后面指定DESC/ASC
    @WhereString    nvarchar(1000)=N'',     --查询条件
    @RecordCount int OUTPUT             --总记录数
    )
    AS
    SET NOCOUNT ON
    --检查对象是否有效
    --IF OBJECT_ID(@tbname) IS NULL
    --BEGIN
    --    RAISERROR(N'对象"%s"不存在',1,16,@tbname)
    --    RETURN
    --END
    --IF OBJECTPROPERTY(OBJECT_ID(@tbname),N'IsTable')=0
    --    AND OBJECTPROPERTY(OBJECT_ID(@tbname),N'IsView')=0
    --    AND OBJECTPROPERTY(OBJECT_ID(@tbname),N'IsTableFunction')=0
    --BEGIN
    --    RAISERROR(N'"%s"不是表、视图或者表值函数',1,16,@tbname)
    --    RETURN
    --END--分页字段检查
    IF ISNULL(@FieldKey,N'')=''
    BEGIN
        RAISERROR(N'分页处理需要主键(或者惟一键)',1,16)
        RETURN
    END--其他参数检查及规范
    IF ISNULL(@PageCurrent,0)<1 SET @PageCurrent=1
    IF ISNULL(@PageSize,0)<1 SET @PageSize=10
    IF ISNULL(@FieldShow,N'')=N'' SET @FieldShow=N'*'
    IF ISNULL(@FieldOrder,N'')=N''
        SET @FieldOrder=N''
    ELSE
        SET @FieldOrder=N'ORDER BY '+LTRIM(@FieldOrder)
    IF ISNULL(@WhereString,N'')=N''
        SET @WhereString=N''
    ELSE
        SET @WhereString=N'WHERE ('+@WhereString+N')'--如果@RecordCount为NULL值,则计算总页数(这样设计可以只在第一次计算总页数,以后调用时,把总页数传回给存储过程,避免再次计算总页数,对于不想计算总页数的处理而言,可以给@RecordCount赋值)
    IF @RecordCount IS NULL
    BEGIN
        DECLARE @sql nvarchar(4000)
        SET @sql=N'SELECT @RecordCount=COUNT(*)'
            +N' FROM '+@tbname
            +N' '+@WhereString
        EXEC sp_executesql @sql,N'@RecordCount int OUTPUT',@RecordCount OUTPUT
    END--计算分页显示的TOPN值
    DECLARE @TopN varchar(20),@TopN1 varchar(20)
    SELECT @TopN=@PageSize,
        @TopN1=(@PageCurrent-1)*@PageSize--第一页直接显示
    IF @PageCurrent=1
        EXEC(N'SELECT TOP '+@TopN
            +N' '+@FieldShow
            +N' FROM '+@tbname
            +N' '+@WhereString
            +N' '+@FieldOrder)
    ELSE
    BEGIN
        --处理别名
        IF @FieldShow=N'*'
            SET @FieldShow=N'a.*'    --生成主键(惟一键)处理条件
        DECLARE @Where1 nvarchar(4000),@Where2 nvarchar(4000),
            @s nvarchar(1000),@Field sysname
        SELECT @Where1=N'',@Where2=N'',@s=@FieldKey
        WHILE CHARINDEX(N',',@s)>0
            SELECT @Field=LEFT(@s,CHARINDEX(N',',@s)-1),
                @s=STUFF(@s,1,CHARINDEX(N',',@s),N''),
                @Where1=@Where1+N' AND a.'+@Field+N'=b.'+@Field,
                @Where2=@Where2+N' AND b.'+@Field+N' IS NULL',
                @WhereString=REPLACE(@WhereString,@Field,N'a.'+@Field),
                @FieldOrder=REPLACE(@FieldOrder,@Field,N'a.'+@Field),
                @FieldShow=REPLACE(@FieldShow,@Field,N'a.'+@Field)
        SELECT @WhereString=REPLACE(@WhereString,@s,N'a.'+@s),
            @FieldOrder=REPLACE(@FieldOrder,@s,N'a.'+@s),
            @FieldShow=REPLACE(@FieldShow,@s,N'a.'+@s),
            @Where1=STUFF(@Where1+N' AND a.'+@s+N'=b.'+@s,1,5,N''),    
            @Where2=CASE
                WHEN @WhereString='' THEN N'WHERE ('
                ELSE @WhereString+N' AND ('
                END+N'b.'+@s+N' IS NULL'+@Where2+N')'    --执行查询
        EXEC(N'SELECT TOP '+@TopN
            +N' '+@FieldShow
            +N' FROM '+@tbname
            +N' a LEFT JOIN(SELECT TOP '+@TopN1
            +N' '+@FieldKey
            +N' FROM '+@tbname
            +N' a '+@WhereString
            +N' '+@FieldOrder
            +N')b ON '+@Where1
            +N' '+@Where2
            +N' '+@FieldOrder)
    END
     
    MSSQL2005set ANSI_NULLS ON
    set QUOTED_IDENTIFIER ON
    go
    ALTER PROCEDURE [dbo].[PROCE_SQL2005PAGECHANGE]
    (
     @TableName varchar(50),            --表名
     @ReFieldsStr varchar(200) = '*',   --字段名(全部字段为*)
     @OrderString varchar(200),         --排序字段(必须!支持多字段不用加order by)
     @WhereString varchar(500) =N'',  --条件语句(不用加where)
     @PageSize int,                     --每页多少条记录
     @PageIndex int = 1 ,               --指定当前为第几页
     @TotalRecord int output            --返回总记录数
    )
    AS
     
    BEGIN        --处理开始点和结束点
        Declare @StartRecord int;
        Declare @EndRecord int; 
        Declare @TotalCountSql nvarchar(500); 
        Declare @SqlString nvarchar(2000);    
        set @StartRecord = (@PageIndex-1)*@PageSize + 1
        set @EndRecord = @StartRecord + @PageSize - 1 
        SET @TotalCountSql= N'select @TotalRecord = count(*) from ' + @TableName;--总记录数语句
        SET @SqlString = N'(select row_number() over (order by '+ @OrderString +') as rowId,'+@ReFieldsStr+' from '+ @TableName;--查询语句
        --
        IF (@WhereString! = '' or @WhereString!=null)
            BEGIN
                SET @TotalCountSql=@TotalCountSql + '  where '+ @WhereString;
                SET @SqlString =@SqlString+ '  where '+ @WhereString;            
            END
        --第一次执行得到
        --IF(@TotalRecord is null)
        --   BEGIN
               EXEC sp_executesql @totalCountSql,N'@TotalRecord int out',@TotalRecord output;--返回总记录数
        --  END
        ----执行主语句
        set @SqlString ='select * from ' + @SqlString + ') as t where rowId between ' + ltrim(str(@StartRecord)) + ' and ' +  ltrim(str(@EndRecord));
        Exec(@SqlString)    
    END
      

  3.   

    /*--用存储过程实现的分页程序 显示指定表、视图、查询结果的第X页
     对于表中主键或标识列的情况,直接从原表取数查询,其它情况使用临时表的方法
     如果视图或查询结果中有主键,不推荐此方法--邹建 2003.09(引用请保留此信息)--*//*--调用示例
     exec p_show '地区资料' exec p_show '地区资料',5,3,'地区编号,地区名称,助记码','地区编号'
    --*/if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[p_show]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)
    drop procedure [dbo].[p_show]
    GOCREATE Proc p_show
    @QueryStr nvarchar(4000), --表名、视图名、查询语句
    @PageSize int=10,   --每页的大小(行数)
    @PageCurrent int=1,   --要显示的页
    @FdShow nvarchar (4000)='', --要显示的字段列表,如果查询结果有标识字段,需要指定此值,且不包含标识字段
    @FdOrder nvarchar (1000)='' --排序字段列表
    as
    declare @FdName nvarchar(250) --表中的主键或表、临时表中的标识列名
     ,@Id1 varchar(20),@Id2 varchar(20) --开始和结束的记录号
     ,@Obj_ID int    --对象ID
    --表中有复合主键的处理
    declare @strfd nvarchar(2000) --复合主键列表
     ,@strjoin nvarchar(4000) --连接字段
     ,@strwhere nvarchar(2000) --查询条件
    select @Obj_ID=object_id(@QueryStr)
     ,@FdShow=case isnull(@FdShow,'') when '' then ' *' else ' '+@FdShow end
     ,@FdOrder=case isnull(@FdOrder,'') when '' then '' else ' order by '+@FdOrder end
     ,@QueryStr=case when @Obj_ID is not null then ' '+@QueryStr else ' ('+@QueryStr+') a' end--如果显示第一页,可以直接用top来完成
    if @PageCurrent=1 
    begin
     select @Id1=cast(@PageSize as varchar(20))
     exec('select top '+@Id1+@FdShow+' from '+@QueryStr+@FdOrder)
     return
    end--如果是表,则检查表中是否有标识更或主键
    if @Obj_ID is not null and objectproperty(@Obj_ID,'IsTable')=1
    begin
     select @Id1=cast(@PageSize as varchar(20))
      ,@Id2=cast((@PageCurrent-1)*@PageSize as varchar(20)) select @FdName=name from syscolumns where id=@Obj_ID and status=0x80
     if @@rowcount=0   --如果表中无标识列,则检查表中是否有主键
     begin
      if not exists(select 1 from sysobjects where parent_obj=@Obj_ID and xtype='PK')
       goto lbusetemp  --如果表中无主键,则用临时表处理  select @FdName=name from syscolumns where id=@Obj_ID and colid in(
       select colid from sysindexkeys where @Obj_ID=id and indid in(
        select indid from sysindexes where @Obj_ID=id and name in(
         select name from sysobjects where xtype='PK' and parent_obj=@Obj_ID
       )))
      if @@rowcount>1  --检查表中的主键是否为复合主键
      begin
       select @strfd='',@strjoin='',@strwhere=''
       select @strfd=@strfd+',['+name+']'
        ,@strjoin=@strjoin+' and a.['+name+']=b.['+name+']'
        ,@strwhere=@strwhere+' and b.['+name+'] is null'
        from syscolumns where id=@Obj_ID and colid in(
        select colid from sysindexkeys where @Obj_ID=id and indid in(
         select indid from sysindexes where @Obj_ID=id and name in(
          select name from sysobjects where xtype='PK' and parent_obj=@Obj_ID
        )))
       select @strfd=substring(@strfd,2,2000)
        ,@strjoin=substring(@strjoin,5,4000)
        ,@strwhere=substring(@strwhere,5,4000)
       goto lbusepk
      end
     end
    end
    else
     goto lbusetemp/*--使用标识列或主键为单一字段的处理方法--*/
    lbuseidentity: 
     exec('select top '+@Id1+@FdShow+' from '+@QueryStr
      +' where '+@FdName+' not in(select top '
      +@Id2+' '+@FdName+' from '+@QueryStr+@FdOrder
      +')'+@FdOrder
      )
     return/*--表中有复合主键的处理方法--*/
    lbusepk:  
     exec('select '+@FdShow+' from(select top '+@Id1+' a.* from
      (select top 100 percent * from '+@QueryStr+@FdOrder+') a
      left join (select top '+@Id2+' '+@strfd+' 
      from '+@QueryStr+@FdOrder+') b on '+@strjoin+'
      where '+@strwhere+') a'
      )
     return/*--用临时表处理的方法--*/
    lbusetemp:  
    select @FdName='[ID_'+cast(newid() as varchar(40))+']'
     ,@Id1=cast(@PageSize*(@PageCurrent-1) as varchar(20))
     ,@Id2=cast(@PageSize*@PageCurrent-1 as varchar(20))exec('select '+@FdName+'=identity(int,0,1),'+@FdShow+'
      into #tb from'+@QueryStr+@FdOrder+'
     select '+@FdShow+' from #tb where '+@FdName+' between '
     +@Id1+' and '+@Id2
     )GO
      

  4.   


    create proc {存储过程名]
    @PAGESIZE int,
    @TSQL varchar(6000)
    as
    begin
     declare @sql varchar(6000)
     select @sql=stuff(@TSQL,1,7,'select top '+cast(@PAGESIZE as varchar)+' ')
     exec(@sql)
    end
      

  5.   


    SET QUOTED_IDENTIFIER ON 
    GO
    SET ANSI_NULLS ON 
    GO
    if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[usp_Page_By_Sql]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)
    drop procedure [dbo].[usp_Page_By_Sql]
    GO
    -- =============================================  
    -- crate  date: <2011/10/31 jack>  
    -- Description: <根据Sql语句分页>  
    -- =============================================  
    CREATE PROCEDURE [dbo].[usp_Page_By_Sql]  
    @PageSize int, --分页大小
    @Sql nvarchar(100) --SQL语句 as
    begin
    declare @Is_Open_Dug bit
    declare @Sql_Str nvarchar(2000)
    --初始化变量
    set @Is_Open_Dug=1
    set @PageSize=isnull(@PageSize,10)
    set @Sql=isnull(@Sql,'select ''0''')

    --Dug Start
    if @Is_Open_Dug=1
    begin
    print char(10)
    print'------------------------[dbo].[usp_Page_By_Sql] begin-------------------'
    print '分页大小 @PageSize='+convert(nvarchar(36),isnull(@PageSize,0))
    print 'SQL语句 @Sql='+isnull(@Sql,'')
    print char(10)
    end --没有表明,没有字段,只有newid来作为Order by,这样就可以用Row_number() 增加一列,然后进行分页,但是没有PageIndex 所以没办法翻页
    set @Sql_Str='select * from (select *,row_number() over(order by newid()) number from('+@Sql+') a) b 
    where number>0 and number <='+convert(nvarchar(36),@PageSize) exec(@Sql_Str) --Dug End
    if @Is_Open_Dug=1
    begin
    print char(10)
    print'------------------------[dbo].[usp_Page_By_Sql] End-------------------'
    end end --测试数据
    if not object_id('tempdb..#test') is null
    begin
    drop table #test
    end
    create table #test (emp_id nvarchar(36),emp_name nvarchar(36),emp_age int)
    insert into #test
    select '1','jack',20 union all
    select '1','jack1',21 union all
    select '1','jack2',20 union all
    select '1','jack3',21 union all
    select '1','jack4',21 union all
    select '1','jack5',20 union all
    select '1','jack',20 union all
    select '1','jack1',21 union all
    select '1','jack2',20 union all
    select '1','jack3',21 union all
    select '1','jack4',21 union all
    select '1','jack5',20 union all
    select '1','jack',20 union all
    select '1','jack1',21 union all
    select '1','jack2',20 union all
    select '1','jack3',21 union all
    select '1','jack4',21 union all
    select '1','jack5',20 union all
    select '1','jack6',21
    exec usp_Page_By_Sql 10,'select * from #test'
      

  6.   

    sql 语句传入这个就报错拉 'select top 10 * from #test '
    只不过还学了个新东西stuff
      

  7.   

     
           CREATE PROCEDURE [dbo].[usp_Page_By_Sql]  
        @PageSize                int,                    --分页大小
        @Sql                    nvarchar(2000)            --SQL语句    as
        begin       declare @Sql_Str nvarchar(2000)
        set @Sql_Str='select * from (select *,row_number() over(order by newid()) number from('+@Sql+') a) b 
    where number>0 and number <='+convert(nvarchar(36),@PageSize)    exec(@Sql_Str)