NHibernate使用ICriteria分页并返回数据库记录总…
2018-06-17 20:13:19来源:未知 阅读 ()
最近在使用NHibernate,发现进行分页查询无法得到数据库记录的总条数,在网上找了很久没找到具体的实现方法,找到的资料都说得不是很清楚,研究了很久终于写出了这样一个方法。
NHibernate下分页要使用Icriteria约束查询条件,但是返回的只有当前页的记录数,无法返回数据库总记录条数,这样在使用的时候就算不出总页数。自定义一个分页响应对象PageResponse用于返回记录总条数和分页查询结果集。
/// <summary> /// 分页响应对象 /// </summary> /// <typeparam name="T"></typeparam> public class PageResponse<T> { public int TotalCount { get; set; } public IList<T> ResultList { get; set; } }
参考网上的方法,先创建一个ICriteria用于查询数据库记录总条数,再clone一个用于分页查询,返回我自己定义的PageResponse对象,包含记录总条数和分页查询结果集。获得数据库记录总数之后要用UniqueResult()将SetProjection()所附加的条件去掉,注意一定要clone一个Icriteria来分页,否则只用一个Icriteria来完成两次操作会报错。
/// <summary> /// 分页查询 /// </summary> /// <param name="pageSize">每页显示记录条数</param> /// <param name="pageNumber">页码</param> /// <returns></returns> public PageResponse<RequestMessage> GetRequestMessageList(int pageNumber, int pageSize) { using (ISession session = sessionFactory.OpenSession()) { ICriteria criteria = session.CreateCriteria(typeof(RequestMessage)); ICriteria pageCriteria = CriteriaTransformer.Clone(criteria); PageResponse<RequestMessage> requestMessage = new PageResponse<RequestMessage>(); requestMessage.TotalCount =Convert.ToInt32(criteria.SetProjection(Projections.RowCount()).UniqueResult()); requestMessage.ResultList = pageCriteria .SetFirstResult(pageSize * (pageNumber < 1 ? 0 : pageNumber - 1)) .SetMaxResults(pageSize) .List<RequestMessage>(); session.Flush(); return requestMessage; } }
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:深入了解浏览器缓存原理
- Django项目中使用qq第三方登录。 2019-08-13
- Python连载30-多线程之进程&线程&线程使用 2019-08-13
- Python学习日记(十) 生成器和迭代器 2019-08-13
- 【Python】语法基础 | 开始使用Python 2019-08-13
- 使用scrapy框架爬取全书网书籍信息。 2019-08-13
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash