分页存储过程(增加了选择字段列表、排序方式参数)
来源:互联网 发布:淘宝服装店介绍 编辑:程序博客网 时间:2024/05/04 14:01
/*
数据库分页存储过程,支持倒序和升序
参数说明:
@tablename:为搜索表名
@tablefield:为表的字段,约定为表的主键,
@where:为搜索表名,要显示所有记录请设为"1=1"
@orderby:为搜索结果排序,如order by id desc
@fieldlist:为字段列表,如userid, username
@curpage:当前页码
@page_record:每页记录条数
@Sort:排序标识(如果是倒序排,参数值为desc,为升序,参数值为asc,跟orderby参数是对应的)
结果: 返回表tablename中满足条件where的第curpage页的page_record条记录,结果按orderby排序
*/
CREATE PROCEDURE proc_CommonPaging
@tablename varchar(100),
@tablefield varchar(20),
@where varchar(5000),
@orderby varchar(500),
@fieldlist varchar(1000),
@curpage int,
@page_record int,
@sort varchar(8)
AS
BEGIN
DECLARE @cmd varchar(8000)
DECLARE @uprecord int
DECLARE @Op varchar(2) -- 操作符
DECLARE @max_min varchar(4) -- 最大/最小计算
SET @op = '<'
SET @max_min = 'MIN'
IF @sort = 'asc'
BEGIN
SET @Op = '>'
SET @max_min = 'MAX'
END
SET @uprecord=@curpage * @page_record
IF @curpage = 0
SET @cmd = 'SELECT TOP '+cast(@page_record AS NVARCHAR)+' '+@fieldlist+' FROM '+@tablename+' WHERE '+@where+' '+@orderby
ELSE
SET @cmd = 'SELECT TOP '+cast(@page_record AS NVARCHAR)+' '+@fieldlist+' FROM '+@tablename+' WHERE '+@where+' AND '+@tablefield+'
'+@op+' (SELECT '+@max_min+'('+@tablefield+') FROM (SELECT TOP '+cast(@uprecord AS NVARCHAR)+' '+@tablefield+' FROM '+@tablename+' WHERE
'+@where+' '+@orderby+') AS TmpTbl ) AND '+@where+' '+@orderby
SET @cmd = @cmd + '; SELECT COUNT(*) FROM '+@tablename+' WHERE '+@where
EXEC(@cmd)
PRINT(@cmd)
END
GO
数据库分页存储过程,支持倒序和升序
参数说明:
@tablename:为搜索表名
@tablefield:为表的字段,约定为表的主键,
@where:为搜索表名,要显示所有记录请设为"1=1"
@orderby:为搜索结果排序,如order by id desc
@fieldlist:为字段列表,如userid, username
@curpage:当前页码
@page_record:每页记录条数
@Sort:排序标识(如果是倒序排,参数值为desc,为升序,参数值为asc,跟orderby参数是对应的)
结果: 返回表tablename中满足条件where的第curpage页的page_record条记录,结果按orderby排序
*/
CREATE PROCEDURE proc_CommonPaging
@tablename varchar(100),
@tablefield varchar(20),
@where varchar(5000),
@orderby varchar(500),
@fieldlist varchar(1000),
@curpage int,
@page_record int,
@sort varchar(8)
AS
BEGIN
DECLARE @cmd varchar(8000)
DECLARE @uprecord int
DECLARE @Op varchar(2) -- 操作符
DECLARE @max_min varchar(4) -- 最大/最小计算
SET @op = '<'
SET @max_min = 'MIN'
IF @sort = 'asc'
BEGIN
SET @Op = '>'
SET @max_min = 'MAX'
END
SET @uprecord=@curpage * @page_record
IF @curpage = 0
SET @cmd = 'SELECT TOP '+cast(@page_record AS NVARCHAR)+' '+@fieldlist+' FROM '+@tablename+' WHERE '+@where+' '+@orderby
ELSE
SET @cmd = 'SELECT TOP '+cast(@page_record AS NVARCHAR)+' '+@fieldlist+' FROM '+@tablename+' WHERE '+@where+' AND '+@tablefield+'
'+@op+' (SELECT '+@max_min+'('+@tablefield+') FROM (SELECT TOP '+cast(@uprecord AS NVARCHAR)+' '+@tablefield+' FROM '+@tablename+' WHERE
'+@where+' '+@orderby+') AS TmpTbl ) AND '+@where+' '+@orderby
SET @cmd = @cmd + '; SELECT COUNT(*) FROM '+@tablename+' WHERE '+@where
EXEC(@cmd)
PRINT(@cmd)
END
GO
- 最新分页存储过程(增加了选择字段列表、排序方式参数)
- 分页存储过程(增加了选择字段列表、排序方式参数)
- 分页存储过程(增加了选择字段列表、排序方式参数)
- 最新分页存储过程(增加了选择字段列表、排序方式参数)
- Mssql分页存储过程(任意字段排序)
- asp.net 存储过程分页字段排序
- 表增加字段存储过程
- 可按任意字段排序的分页存储过程
- 可以多个字段排序的分页存储过程
- 排序字段值重复时的分页存储过程
- 可按任意字段排序的分页存储过程
- 可按任意字段排序的分页存储过程
- 可按任意字段排序的分页存储过程
- 拼串的方式实现根据不同的字段进行分页(存储过程)
- Oracle存储过程(分页、模糊查找、排序、按字段区间查找)etc.以及JAVA代码
- 优先选择之sql server 分页的存储过程(已测试可用,可用非维一值字段排序分页)这个速度更快
- 分页存储过程(支持多字段排序)及调用& output多参数存储过程调用应用
- 分页存储过程(支持多字段排序)及调用& output多参数存储过程调用应用
- Delphi&Excel
- 时间格式
- 用VisualStudio2005生成浏览器帮助对象
- 盈利模式研究——网站盈利9问
- J2ME的常见异常,请教高手。我刚学就报了个异常,请教???
- 分页存储过程(增加了选择字段列表、排序方式参数)
- Solaris 10开启SSH服务
- 了解ASP.NET底层架构
- XDoclet --hibernate标签 简单介绍
- .net下实现Word动态填加数据打印
- 用DataFormatString格式化GridView
- 使用Eclipse3.2.1+STP.0.4.0+Apache Tuscany开发SCA的Java组件(4)安装运行错误问题修正篇
- D-Day +19 of .NET 沉寂已久的RP之神终于重生~AMT实习努力进行中!
- 推荐阅读:Paul Oldfield: 如何正确理解敏捷?