hibernate中带查询条件的分页
所谓分页,从数据库中分,则是封装一个分页类。利用分页对象进行分页。
但,分页往往带查询条件。
分页类的三个重要数据:【当前页码数】,【数据库中的总记录数】,【每页显示的数据的条数】
原理:select * from 【表名】 where 【字段名】 like 【'%条件%'】 limit 【开始查询的索引】,【每页显示的数据】
带查询条件的分页分两步
(1)第一步:查询出符合条件的数据的总条数
---->select count(*) from 【表名】 where 【字段名】 like 【条件】
(2)第二步:提供三个重要数据,生成分页对象,然后查询数据库中指定页码的数据
---->select * from 【表名】 where 【字段名】 like 【'%条件%'】 limit 【开始查询的索引】,【每页显示的数据】
hibernate框架下的分页【带查询条件的分页核心源代码】
(1)获取符合条件的的数据的总记录数的方法
/**
* 获取数据库中带查询条件的数据的记录数
* @Title: countByName
* @Description: TODO(这里用一句话描述这个方法的作用)
* @param seachName 查询条件
* @return
* @return Integer 返回符合条件的数据的总记录数
* @author 尚晓飞
* @date 2014-7-1 上午9:22:14
*/
public Integer countByName(final String seachName){
return super.getHibernateTemplate().execute(new HibernateCallback<Integer>() {
public Integer doInHibernate(Session session)
throws HibernateException, SQLException {
Query query=session.createSQLQuery("select count(*) from sys_user where sys_user_name LIKE ?");
query.setParameter(0, "%"+seachName+"%");
Number number= (java.lang.Number) query.uniqueResult();
return number.intValue();
}
});
}
(2)跟据符合条件的数据总记录数,前台提供的当前页码数,每页显示的数据条数,生成分页对象
//获取分页对象(当前页码数,符合条件的数据的总记录数,每页显示的数据条数)
this.page=new Page(num, countRecords, pageRecords);
(3)根据分页对象,查询条件,利用hibernate框架进行分页(可以用sql语句分页,此处用hql分页,也是hibernate的分页)
/**
*
* @Title: queryByQueryName
* @Description: TODO(这里用一句话描述这个方法的作用)
* @param queryName 查询条件的参数
* @param firstResult 从第几条数据开始查询(分页对象提供)
* @param maxResult 每页显示的数据条数(分页对象提供)
* @return
* @return List<SysUser> 返回指定页码的数据集合
* @author 尚晓飞
* @date 2014-7-1 下午5:02:07
*/
@SuppressWarnings("unchecked")
public List<SysUser> queryByQueryName( final String queryName,final Integer firstResult,final Integer maxResult){
return (List<SysUser>)super.getHibernateTemplate().executeFind(new HibernateCallback<List<SysUser>>() {
@Override
public List<SysUser> doInHibernate(Session session)
throws HibernateException, SQLException {
Query query=session.createQuery("from SysUser where sysUserName like ?");//带查询条件的分页hql语句
query.setParameter(0,"%"+queryName+"%");
query.setFirstResult(firstResult);//从第几条数据开始查询
query.setMaxResults(maxResult);//每页显示多少条数据
return query.list();
}
});
}
(4)分页类【仅供参考,省去set,get方法,代码简单,思路重要】
public class Page{
//每页显示数据条数
private int pageSize;
//当前页码数
private int pageNum;
//数据库中总记录数
private int rowCount;
//总页数
private int pageCount;
//从多少条记录开始查询
private int rowStart;
//是否有上一页
private boolean hasPrevious=false;
//上一页
private int previousPage;
//首页
private int firstPage;
//是否有下一页
private boolean hasNext=false;
//下一页
private int nextPage;
//末尾页
private int lastPage;
//每页显示的页码数
private int everyPageCount=10;
//每页开始的页码数
private int everyPageStart;
//每页结束的页码数
private int everyPageEnd;
public Page(){}
public Page(String pageSize, String pageNum, int rowCount) {
this.pageSize=pageSize==null?10:Integer.parseInt(pageSize);
this.pageNum=pageNum==null?1:Integer.parseInt(pageNum);
this.rowCount=rowCount;
//总页数
this.pageCount=(int)Math.ceil(this.rowCount*1.0/this.pageSize);
//当删除最后一页数据时,会造成pageNum>pageCount,所以赋值。
if(this.pageNum>this.pageCount){
this.pageNum=this.pageCount;
}
//每次从第几条记录开始查 select * from onesong limit rowStart ,pageSize
this.rowCount=(this.pageNum-1)*this.pageSize;
//当页码数大于1则存在上一页,和首页
if(this.pageNum>1){
this.hasPrevious=true;
this.previousPage=this.pageNum-1;
this.firstPage=1;
}
//当页码数小于1则存在下一页,和尾页
if(this.pageNum<this.pageCount){
this.hasNext=true;
this.nextPage=this.pageNum+1;
this.lastPage=this.pageCount;
}
//每页显示的页码数的开始和结束
this.everyPageStart=(this.pageNum-this.pageSize/2)<=0?1:(this.pageNum-this.pageSize/2);
this.everyPageEnd=(this.everyPageStart+this.everyPageCount-1)>=this.pageCount?pageCount:(this.everyPageStart+this.everyPageCount-1);
}
}
hibernate中带查询条件的分页的更多相关文章
- Thinkphp 带查询条件数据分页
//查询条件中如果有中文 $keyword= urldecode(I("request.keyword")); if ($keyword!=""){ $Mode ...
- thinkphp带查询条件的分页
<!DOCTYPE HTML> <html lang="en-US"> <head> <meta charset="UTF-8& ...
- exp导出一个表中符合查询条件的数据
原文地址:exp导出一个表中符合查询条件的数据 作者:charsi 导出一个表中的部分数据,使用QUERY参数,如下导出select * from test where object_id>50 ...
- JavaWeb_(Hibernate框架)Hibernate中数据查询语句SQL基本用法
本文展示三种在Hibernate中使用SQL语句进行数据查询基本用法 1.基本查询 2.条件查询 3.分页查询 package com.Gary.dao; import java.util.List; ...
- Hibernate 笔记 HQL查询 条件查询,聚集函数,子查询,导航查询
在hibernate中进行多表查询,每个表中各取几个字段,也就是说查询出来的结果集并没有一个实体类与之对应,如何解决这个问题? 解决方案一,按照Object[]数据取出数据,然后自己组bean 解决方 ...
- JPA或Hibernate中使用原生SQL实现分页查询、排序
发生背景:前端展示的数据需要来自A表和D表拼接,A表和D表根据A表的主键进行关联,D表的非主键字段关联C表的主键,根据条件筛选出符合的数据,并且根据A表的主键关联B表的主键(多主键)的条件,过滤A表中 ...
- hibernate 中HQL查询
由于比较简单,在此处只写一些HQL语言. 表关系,多对一. CREATE TABLE `user` ( `id` ) NOT NULL AUTO_INCREMENT, `uname` varchar( ...
- JavaWeb_(Hibernate框架)Hibernate中数据查询语句HQL基本用法
HQL(Hibernate Query Language) 是面向对象的查询语言, 它和 SQL 查询语言有些相似. 在 Hibernate 提供的各种检索方式中, HQL 是使用最广的一种检索方式. ...
- Hibernate中Hql查询
这篇随笔将会记录hql的常用的查询语句,为日后查看提供便利. 在这里通过定义了三个类,Special.Classroom.Student来做测试,Special与Classroom是一对多,Class ...
随机推荐
- java Calendar类得到每个月的周末是几号的工具方法
public static List getWeekendInMonth(int year, int month) { List list = new ArrayList(); Calendar ca ...
- Linux3.10.0块IO子系统流程(2)-- 构造、排序、合并请求
Linux块设备可以分为三类.分别针对顺序访问物理设备.随机访问物理设备和逻辑设备(即“栈式设备”) 类型 make_request_fn request_fn 备注 SCSI 设备等 从bio构 ...
- Cracking The Coding Interview 2.5
这题的思想来自于http://hawstein.com/posts/2.5.html,重新实现了一下 用hash来记录循环的起点 //Given a circular linked list, imp ...
- 用户登录页面——jdbc
登录页面程序login.jsp <%@ page language="java" import="java.util.*" pageEncoding=&q ...
- jdbc中Class.forName(driverName)的作用
上次面试别人问我jdbc的过程: 我是这样回答的: Class.forName加载驱动 DriverManager.connect(url,username, password)获取连接对象 conn ...
- 2017 秦皇岛CCPC Balloon Robot (ZOJ 3981)
题意:给出n个队伍,m个座位,q次A题的队伍与时间,下一行是n个队伍的坐的位置,再下面q行就是第x个队再第y秒A出一道题,然后有一个机器人,开始位置由你选,他每走一步 他就会向右走一格,走到m的时候会 ...
- <Spark><Advanced Programming>
Introduction 介绍两种共享变量的方式: accumulators:聚集信息 broadcast variables:高效地分布large values 介绍对高setup costs任务的 ...
- L293 给地球降温
Countries look at ways to tinker with Earth’s thermostat The idea of cooling the climate with strato ...
- oracle中有关初始化参数文件的几个视图对比
涉及oracle中有关初始化参数文件的几个视图主要有:v$paraemter,v$parameter2,v$system_parameter,v$system_parameter2,v$spparam ...
- nginx的日志切割
nginx日志默认情况下统统写入到一个文件中,文件会变的越来越大,非常不方便查看分析.以日期来作为日志的切割是比较好的,通常我们是以每日来做统计的.下面来说说nginx日志切割. 如果我们使用的是yu ...