最通用的ibatis.Net使用sql server存储过程返回分页数据的详细例子
1、ibatis.Net配置文件Common.xml
- <?xml version="1.0" encoding="utf-8" ?>
- <sqlMap namespace="Common" xmlns="http://ibatis.apache.org/mapping"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" >
- <alias>
- <typeAlias alias="PageCriteria" type="GM.Model.PageCriteria,GM.Model" />
- </alias>
- <parameterMaps>
- <parameterMap id="PageMap" class="PageCriteria">
- <parameter property="TableName" />
- <parameter property="PrimaryKey"/>
- <parameter property="Fields" />
- <parameter property="Condition" />
- <parameter property="CurrentPage" />
- <parameter property="PageSize" />
- <parameter property="Sort" />
- <parameter property="RecordCount" direction="Output" column="RecordCount"/>
- </parameterMap>
- </parameterMaps>
- <statements>
- <procedure id="GetPageData" parameterMap="PageMap" resultClass="Hashtable" >
- [dbo].[ProcGetPageData]
- </procedure>
- </statements>
- </sqlMap>
2、通用分页存储过程ProcGetPageData
- CREATE PROCEDURE [dbo].[ProcGetPageData]
- ( @TableName VARCHAR(1000), --表名,多表是请使用 tA a inner join tB b On a.AID = b.AID
- @PrimaryKey NVARCHAR(100), --主键,可以带表头 a.AID
- @Fields NVARCHAR(2000) = '*',--读取字段
- @Condition NVARCHAR(3000) = '',--Where条件
- @CurrentPage INT = 1, --开始页码
- @PageSize INT = 10, --页大小
- @Sort NVARCHAR(200) = '', --排序字段
- @RecordCount INT = 0 OUT
- )
- AS
- DECLARE @strWhere VARCHAR(2000)
- DECLARE @strsql NVARCHAR(3900)
- IF @Condition IS NOT NULL AND len(ltrim(rtrim(@Condition)))>0
- BEGIN
- SET @strWhere = ' WHERE ' + @Condition + ' '
- END
- ELSE
- BEGIN
- SET @strWhere = ''
- END
- IF (charindex(ltrim(rtrim(@PrimaryKey)),@Sort)=0)
- BEGIN
- IF(@Sort='')
- SET @Sort = @PrimaryKey + ' DESC '
- ELSE
- SET @Sort = @Sort+ ' , '+@PrimaryKey + ' DESC '
- END
- SET @strsql = 'SELECT @RecordCount = Count(1) FROM ' + @TableName + @strWhere
- EXECUTE sp_executesql @strsql ,N'@RecordCount INT output',@RecordCount OUTPUT
- IF @CurrentPage = 1 --第一页提高性能
- BEGIN
- SET @strsql = 'SELECT TOP ' + str(@PageSize) +' '+@Fields
- + ' FROM ' + @TableName + ' ' + @strWhere + ' ORDER BY '+ @Sort
- END
- ELSE
- BEGIN
- /* 执行动态sql*/
- DECLARE @START_ID NVARCHAR(50)
- DECLARE @END_ID NVARCHAR(50)
- SET @START_ID = CONVERT(NVARCHAR(50),(@CurrentPage - 1) * @PageSize + 1)
- SET @END_ID = CONVERT(NVARCHAR(50),@CurrentPage * @PageSize)
- SET @strsql = ' SELECT *
- FROM (SELECT ROW_NUMBER() OVER(ORDER BY '+@Sort+') AS rownum,
- '+@Fields+ '
- FROM '+@TableName + @strWhere +') AS XX
- WHERE rownum BETWEEN '+@START_ID+' AND ' +@END_ID +' ORDER BY XX.rownum ASC'
- END
- EXEC(@strsql)
- RETURN
- GO
3、分页相关信息类PageCriteria
- public class PageCriteria
- {
- private string _TableName;
- public string TableName
- {
- get { return _TableName; }
- set { _TableName = value; }
- }
- private string _Fileds = "*";
- public string Fields
- {
- get { return _Fileds; }
- set { _Fileds = value; }
- }
- private string _PrimaryKey = "ID";
- public string PrimaryKey
- {
- get { return _PrimaryKey; }
- set { _PrimaryKey = value; }
- }
- private int _PageSize = 10;
- public int PageSize
- {
- get{return _PageSize;}
- set{_PageSize = value;}
- }
- private int _CurrentPage = 1;
- public int CurrentPage
- {
- get { return _CurrentPage; }
- set { _CurrentPage = value; }
- }
- private string _Sort = string.Empty;
- public string Sort
- {
- get { return _Sort; }
- set { _Sort = value; }
- }
- private string _Condition = string.Empty;
- public string Condition
- {
- get { return _Condition; }
- set { _Condition = value; }
- }
- private int _RecordCount;
- public int RecordCount
- {
- get { return _RecordCount; }
- set { _RecordCount = value; }
- }
- }
3、调用存储过程方法返回数据

- public IList<Hashtable> GetListForPageSummary(PageCriteria criteria)
- {
- criteria.TableName ="Person";
- criteria.PrimaryKey = "Id";
- criteria.Fields = @"*";
- return Mapper.Instance().QueryForList<Hashtable>("GetPageData", criteria);
- }
注意:Condition不用再加where关键词了。
文章来源:http://www.lanhusoft.com/Article/97.html
最通用的ibatis.Net使用sql server存储过程返回分页数据的详细例子的更多相关文章
- Sql Server 存储过程中查询数据无法使用 Union(All)
原文:Sql Server 存储过程中查询数据无法使用 Union(All) 微软Sql Server数据库中,书写存储过程时,关于查询数据,无法使用Union(All)关联多个查询. 1.先看一段正 ...
- sql server中的分页数据查询
1.引言 今天在工作中遇到一个需要进行sql server分页数据查询的问题,但是分页数据查询的sql却忘记了,最终通过查询资料解决了该问题.现在把解决方法记下,以备查阅. 在这里需要感谢博客园的Ql ...
- SQL Server 存储过程进行分页查询
CREATE PROCEDURE prcPageResult -- 获得某一页的数据 -- @currPage INT = 1 , --当前页页码 (即Top currPage) @showColum ...
- sql server存储过程返回数据只有一个字符
SqlParameter[] param = { new SqlParameter("@shopId",shopId), new SqlParameter("@newSh ...
- 一条sql 执行查询列表 返回分页数据以及总数 totalCount
SELECT ID,Name,Age,Addr,Tel,COUNT(1) OVER() AS totalFROM dbo.Student WHERE Age>22 ORDER BY id DES ...
- 恢复SQL Server被误删除的数据(再扩展)
恢复SQL Server被误删除的数据(再扩展) 大家对本人之前的文章<恢复SQL Server被误删除的数据> 反应非常热烈,但是文章里的存储过程不能实现对备份出来的日志备份里所删数据的 ...
- 恢复SQL Server被误删除的数据
恢复SQL Server被误删除的数据 <恢复SQL Server被误删除的数据(再扩展)> 地址:http://www.cnblogs.com/lyhabc/p/4620764.html ...
- 初识 Sql Server存储过程
开篇语 之前的公司并未使用存储过程来做项目,所以小生对存储过程的调用.使用也是一知半解,刚好这家公司就大量用到了存储过程 这次做的功能,为了保持风格一致,也是需要使用存储过程来实现动态sql和数据分页 ...
- sql server存储过程中SELECT 与 SET 对变量赋值的区别
SQL Server 中对已经定义的变量赋值的方式用两种,分别是 SET 和 SELECT. 对于这两种方式的区别,SQL Server 联机丛书中已经有详细的说明,但很多时候我们 并没有注意,其实这 ...
随机推荐
- docker rmi all
docker stop $(docker ps -a -q) docker rm $(docker ps -a -q)
- 转 图片缓存之内存缓存技术LruCache,软引用
每当碰到一些大图片的时候,我们如果不对图片进行处理就会报OOM异常,这个问题曾经让我觉得很烦恼,后来终于得到了解决,那么现在就让我和大家一起分享一下吧.这篇博文要讲的图片缓存机制,我接触到的有两钟,一 ...
- 基于JAVA语言的多线程技术
1.简介 多线程技术属于操作系统范围内的知识: 进程与线程 可以这么理解,一个应用程序就是一个进程,在一个进程中包含至少一个线程:进程就是线程的容器,真正工作.处理任务的是线程. 进程是操作系统分配资 ...
- public private proteccted区别
public公共,加上这个修饰的类或属性,可以在同一个包或者别的包里面访问 private私有的,加上这个修饰的类或属性,只能在同类里访问,同包和别的包不能访问 protected保护,加上这个修饰的 ...
- 一个基于jQuery的简单树形菜单
在工作中的项目使用的是一个前端基于 jQuery easyui 的一个系统,其中左侧的主菜单使用的是 easyui 中的 tree 组件,不是太熟悉,不过感觉不是太好用. 比如 easyui 中的 t ...
- ural1682 Crazy Professor
Crazy Professor Time limit: 1.0 secondMemory limit: 64 MB Professor Nathan Mathan is crazy about mat ...
- cell选中与取消选中调用的方法
//选中与取消选中都会调用哦,注意!!- (void)setSelected:(BOOL)selected animated:(BOOL)animated{ [super setSelected:se ...
- angular Jsonp的坑
angular 为了解决跨域问题 一些第三方接口会提供jsonp来调用,需要使用callback=JSON_CALLBACK来处理 这个时候问题来了,有些借口是不支持callback里面带有点语法的, ...
- 1084:XX开公司<回溯>
Description 2020年,xx开了一家拥有N个员工的大公司.每天,xx都要分配N项工作给他的员工,但是,由于能力的不同,每个人对处理相同工作所需要的时间有快有慢.众所周知,xx是一个非常重视 ...
- 基于Nginx的Rtmp流媒体服务器环境搭建
一.编译安装 wget http://nginx.org/download/nginx-1.4.2.tar.gz wget https://github.com/arut/nginx-rtmp-mod ...