Sql server存储过程和C#分页类简化你的代码

来源:网络整理 责任编辑:栏目编辑 发表时间:2013-07-01 12:12 点击:
 

Sqlserver存储过程和C#分页类简化你的代码!
在最近的项目中,由于要用到自定义分页的功能,本人就在网上找了个存储过程。结合C#写了个分页类。由于本人第一次写文章。写得不好,大家不要扔鸡蛋。。

下面是存储过程(sqlserver2000下通过)


--最通用的分页存储过程
-- 获取指定页的数据 
 
CREATE PROCEDURE Pagination 
 
@tblName   varchar(255),       -- 表名 
 
@strGetFields varchar(1000) = '*',  -- 需要返回的列 
 
@fldName varchar(255)='',      -- 排序的字段名 
 
@PageSize   int = 10,          -- 页尺寸 
 
@PageIndex  int = 1,           -- 页码 
 
@doCount  bit = 0,   -- 返回记录总数, 非 0 值则返回 
 
@OrderType bit = 0,  -- 设置排序类型, 非 0 值则降序 
 
@strWhere  varchar(1500) = ''  -- 查询条件 (注意: 不要加 where) 
 
AS 
 
declare @strSQL   varchar(5000)       -- 主语句 
 
declare @strTmp   varchar(110)        -- 临时变量 
 
declare @strOrder varchar(400)        -- 排序类型 
 
 
 
if @doCount != 0 
 
 begin 
 
   if @strWhere !='' 
 
   set @strSQL = 'select count(*) as Total from ['+ @tblName +'] where '+ @strWhere 
 
   else 
 
   set @strSQL = 'select count(*) as Total from ['+ @tblName +']'
 
end 
 
--以上代码的意思是如果@doCount传递过来的不是0,就执行总数统计。以下的所有代码都
--是@doCount为0的情况 
 
else 
 
begin 
 
 
 
if @OrderType != 0 
 
begin 
 
   set @strTmp = '<(select min' 
 
set @strOrder = ' order by ['+ @fldName +'] desc'
 
--如果@OrderType不是0,就执行降序,这句很重要! 
 
end 
 
else 
 
begin 
 
   set @strTmp = '>(select max'
 
   set @strOrder = ' order by ['+ @fldName +'] asc'
 
end 
 
 
 
if @PageIndex = 1 
 
begin 
 
   if @strWhere != ''   
 
    set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+ '  from ['+ @tblName +'] where ' + @strWhere + ' ' + @strOrder 
 
    else 
 
    set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+ '  from ['+ @tblName +'] '+ @strOrder 
 
--如果是第一页就执行以上代码,这样会加快执行速度 
 
end 
 
else 
 
begin 
 
--以下代码赋予了@strSQL以真正执行的SQL代码 
 
set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+ '  from [' + @tblName +'] where [' + @fldName + ']' + @strTmp + '(['+ @fldName + ']) 
from (select top ' + str((@PageIndex-1)*@PageSize) + ' ['+ @fldName + '] from ['+ @tblName +']' + @strOrder + ') as tblTmp)'+ @strOrder 
 
 
 
if @strWhere != '' 
 
   set @strSQL = 'select top ' + str(@PageSize) +' '+@strGetFields+ '  from ['+ @tblName +'] where [' + @fldName +

    发表评论
    请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
    用户名: 验证码:点击我更换图片
    最新评论 更多>>

    推荐热点

    • 用C#制作屏幕捕获程序
    • .NET程序员项目开发必知必会—Dev环境中的集成测试用例执行时上
    • 遍历ArrayList易犯错误
    • C#对XML操作:一个处理XML文件的类(1)
    • .NET简谈反射(动态调用)
    • 使用C#编写LED样式时钟控件
    • DataList嵌套问题 如何删除内层子DataList的记录
    • 怎样用C#实现完整文档打印功能
    • .NET简谈自定义事务资源管理器
    网站首页 - 友情链接 - 网站地图 - TAG标签 - RSS订阅 - 内容搜索
    Copyright © 2008-2015 计算机技术学习交流网. 版权所有

    豫ICP备11007008号-1