When Compromise Is Not An Option

导航

<2008年5月>
27282930123
45678910
11121314151617
18192021222324
25262728293031
1234567

统计

公告

这里内容虽然还不精彩,但每篇文章都是原创,望大家和我讨论问题。您的每一个评论,都是我的动力,我一定并虚心接受批评和鼓励。
联系方式:
MAIL:
zaluao#gmail.com

与我联系

搜索

 

常用链接

留言簿(1)

我参与的团队

我的标签

随笔分类

文章分类

最新随笔

最新评论

阅读排行榜

评论排行榜

从通用分页存储过程[ROWCOUNT方式]抽出适合自己需求的分页过程

     通用分页存储过程很实用,但毕竟不是全适用于一些环境,譬如我遇到过一种情况,需要先外链两个表,然后再关联几个表,总之参数传递很烦人,这里不细说了,现在只谈实现查询后,怎么分页的简单技巧
1,建立用户函数
CREATE   function   F_xxxx(@ID  nvarchar(36),@Key nvarchar(36),......)
{
......//这里查询出你需要分页的所有数据,可以带参数来查询
}
建函数的目的是为了整合查询的数据,主要是可以带入参数,很方便.
注,函数中没有exec语句,不可以拼接SQL,不过可以调用存储过程.
2,建分页存储过程,具体框架和说明如下
/*080520  by zjyaoo@live.cn*/  
CREATE PROCEDURE dbo.SPCustomPaging
    (
    
@PageSize int =15--页面大小
    @PageNumber int =1--页码
    @传入到函数的参数1 nvarchar(36), --传入到函数的参数,这里参数个数根据建的函数来决定
    @传入到函数的参数2 nvarchar(36), --传入到函数的参数,这里参数个数根据建的函数来决定
    @StrWhere nvarchar(2000)=' AND 1=1' , --条件,注:传入的@StrWhere需要replace.(''','''')处理
    @RecordCount int =0  output  --返回总的条数
    )
AS
DECLARE @strStartRow int
IF @PageNumber < 1
    
SET @PageNumber = 1
SET @strStartRow =(@PageNumber - 1)* @PageSize + 1  --设置其实页码
--
--
DECLARE @str_Count_SQL nvarchar(500
SET @str_Count_SQL= 'SELECT @TotalCount=count(*) FROM  [F_建立的的函数]('''+@函数参数1+''','''+@函数参数2+''') Where 1=1 '  + @StrWhere  --1=1,用于外接条件
EXEC sp_executesql @str_Count_SQL,N'@TotalCount int=0 output',@RecordCount output  --获取总的条数
Declare @Sql nvarchar(1000)
set @Sql =
'DECLARE  @SortColumn  nvarchar(255)  --建几个临时变量
DECLARE  @SortNullValue  nvarchar(255) 
DECLARE  @PKStartValue  nvarchar(255)  
SET @SortNullValue = CAST(
'''' as int)
SET ROWCOUNT  
'+  cast(@strStartRow   as  nvarchar(5))  +'   --整数转为字符
SELECT @SortColumn= isNull([函数中的分类字段] ,@SortNullValue), @PKStartValue = [函数中的关键字段]    FROM   [F_建立的的函数](
'''+@函数参数1+''','''+@函数参数2+''')   Where 1=1   '+@StrWhere +'  ORDER BY [函数中的分类字段], [再加个函数中的关键字段] Desc 
SET ROWCOUNT   
'+ cast(@PageSize   as  nvarchar(5)) +'    --整数转为字符
SELECT * FROM  F_ManufacturerDiscount(
'''+@OrgID+'''
 WHERE  (isNull([函数中的分类字段],@SortNullValue)>@SortColumn or (isNull([函数中的分类字段],@SortNullValue)=@SortColumn and [函数中的关键字段]<=@PKStartValue))  
'+@StrWhere +'  ORDER BY [函数中的分类字段],[函数中的关键字段] Desc
RETURN
'
Exec (@Sql)
GO
Tag标签: SQL

posted on 2008-05-20 20:38 Zaluao 阅读(363) 评论(1)  编辑 收藏 网摘 所属分类: .NET SKILL

评论

#1楼  2008-05-21 12:59 金色海洋(jyk)      

其实我挺不理解为什么要在存储过程里面组合SQL语句,我是在分页控件里面组合SQL语句的,这样就会方便很多。

http://www.cnblogs.com/jyk/category/135294.html   回复  引用  查看    


标题  
姓名  
主页
Email (博主才能看到) 
验证码 *  看不清,换一张 [登录][注册]
内容(请不要发表任何与政治相关的内容)  
  登录  使用高级评论  新用户注册  返回页首  恢复上次提交      
该文被作者在 2008-05-20 20:40 编辑过
Google站内搜索

相关文章:


相关搜索:
SQL

相关链接: