控件中国网现已改版,您看到的是老版本网站的镜像,系统正在为您跳转到新网站首页,请稍候.......
中国最专业的商业控件资讯网产品咨询电话:023-67870900 023-67871946
产品咨询EMAIL:SALES@COMPONENTCN.COM

数据库分页存储过程

作者:佚名 出处:互联网 2011年05月25日 阅读:

数据库分页存储过程
 
CREATE PROCEDURE [dbo].[P_DOCGetTest]--20,2,0

@orderCellName NVARCHAR(50),

@sortOrder NVARCHAR(50),

@pageSize INT,

@pageIndex INT,

@RowCount INT OUTPUT

AS

BEGIN

  DECLARE @SQL NVARCHAR(MAX)

  DECLARE @SQL_COUNT NVARCHAR(MAX)

  DECLARE @BEGIN INT

   DECLARE @END INT

   SET @BEGIN = CAST(((@PageIndex - 1) * @PageSize + 1) AS VARCHAR(15))

   SET @END = CAST((@PageSize * @PageIndex) AS VARCHAR(15))

  IF(ISNULL(@orderCellName,'')='')

   BEGIN

     SET @orderCellName='T.Id'

   END

 

   IF(ISNULL(@sortOrder,'')='')

   BEGIN

     SET @sortOrder='ASC'

  END


  SET @SQL='SELECT ROW_NUMBER() OVER(ORDER BY ' + @orderCellName + ' ' + @sortOrder + ') as RowId

      T.Id,

      T.Name,

      T.Remark

     FROM [test] AS T '

  SET @SQL_COUNT = 'SELECT @RowCount = COUNT(0) FROM (' + @SQL + ') AS t'


  SET @SQL='SELECT * FROM (' + @SQL + ') AS T WHERE T.RowId ' +

        'BETWEEN ' + CONVERT(VARCHAR(8),@Begin) + ' AND ' + CONVERT(VARCHAR(8),@End)

  EXEC SP_EXECUTESQL @SQL_COUNT,N'@RowCount INT OUTPUT',@RowCount OUTPUT

  EXEC(@SQL)

  PRINT @SQL

END

 

热推产品

  • ActiveReport... 强大的.NET报表设计、浏览、打印、转换控件,可以同时用于WindowsForms谀坔攀戀Forms平台下......
  • AnyChart AnyChart使你可以创建出绚丽的交互式的Flash和HTML5的图表和仪表控件。可以用于仪表盘的创......
首页 | 新闻中心 | 产品中心 | 技术文档 | 友情连接 | 关于磐岩 | 技术支持中心 | 联系我们 | 帮助中心 Copyright-2006 ComponentCN.com all rights reserved.重庆磐岩科技有限公司(控件中国网) 版权所有 电话:023 - 67870900 传真:023 - 67870270 产品咨询:sales@componentcn.com 渝ICP备12000264号 法律顾问:元炳律师事务所 重庆市江北区塔坪36号维丰创意绿苑A座28-5 邮编:400020
在线客服
在线客服系统
在线客服
在线客服系统