今天闲来无事,摆弄了一下分页,突然发现很多代码长时间不用就生梳了,虽然有些基础,但没有一篇整合的。这里还是简单示例,主要是以后自己翻着看不用百度找啊找找不到一篇想要的

1、PageBean实体类,一页出的内容全都有

 package entity;

 import java.util.List;

 /**
* 定义一个分页对象
* @author 0
*
*/
public class PageBean<T> {
private int pageNo;//当前页码
private int totalPageCount;//总页码
private int totalCount;//总条数
private int pageSize=3;//每页显示条数
private int upPageNo;//上一页
private int nextPageNo;//下一页
//一页返回的数据集合
private List<?> list;
public int getPageNo() {
return pageNo;
}
public void setPageNo(int pageNo) {
//如果当前页码大于0,才设置当前页码值
if(pageNo>0){
this.pageNo=pageNo;
}
}
public int getTotalPageCount() {
return totalPageCount;
}
public void setTotalPageCount(int totalPageCount) {
if(this.getTotalCount()%this.pageSize==0){
this.totalPageCount=this.getTotalCount()/this.pageSize;
}else if(this.getTotalCount()%this.pageSize >0){
this.totalPageCount=this.getTotalCount()/this.pageSize +1;
}else{
this.totalPageCount = 0;
}
}
public int getTotalCount() {
return totalCount;
}
public void setTotalCount(int totalCount) {
this.totalCount = totalCount;
}
public int getPageSize() {
return pageSize;
}
public void setPageSize(int pageSize) {
this.pageSize = pageSize;
}
public int getUpPageNo() {
return upPageNo;
}
//对上一页进行判断
public void setUpPageNo(int upPageNo) {
//如果当前页>1
if(this.pageNo>1){
this.upPageNo = this.pageNo-1;
}
} public int getNextPageNo() {
return nextPageNo;
}
//对下一页进行判断
public void setNextPageNo(int nextPageNo) {
//如果当前页>0且小于总页数,则可以有下一页
if(this.pageNo>0 && this.pageNo < this.totalPageCount){
this.upPageNo = this.pageNo+1;
}
} public List<?> getList() {
return list;
}
public void setList(List<?> list) {
this.list = list;
} }

2、dao层实现类,这里框架用的hibernate。hibernate作dao层的数据处理,真是太方便了

 package dao.impl;

 import java.util.List;

 import org.hibernate.Query;
import org.hibernate.Session; import util.HibernateSessionFactory; import dao.InfoMationDao;
import entity.Info;
import entity.PageBean; public class InfoMationDaoImpl implements InfoMationDao { public PageBean<Info> getInfoByPage(int pageNo, String where) {
Session session=HibernateSessionFactory.getSession();
PageBean<Info> pagebean=new PageBean<Info>(); try { //求数据总量
int totalCount = ((Number) session.createQuery("select count(*) as count from Info where 1=1 "+where).uniqueResult()).intValue() ;
//总数、当前页、总页数
pagebean.setTotalCount(totalCount);
pagebean.setPageNo(pageNo);
pagebean.setTotalPageCount(totalCount/pagebean.getPageSize());
pagebean.setUpPageNo(pageNo-1);
pagebean.setNextPageNo(pageNo+1); //建立查询
Query query = session.createQuery("from Info where 1=1 "+where);
//设置起始行pageSize*pageNo,(pageNo-1)*pageSize
query.setFirstResult((pageNo-1)*pagebean.getPageSize());
//设置每页条数
query.setMaxResults(pagebean.getPageSize());
List<Info> infolist = query.list();
pagebean.setList(infolist); } catch (Exception e) {
e.printStackTrace();
}
return pagebean;
} /* public static void main(String[] args) {
InfoMationDao im=new InfoMationDaoImpl();
int pageno=1;
String where="";
PageBean<Info> pb = im.getInfoByPage(pageno, where);
System.out.println(pb.getList().size());
}*/
}

so easy!

hibernate+pageBean实现分页dao层功能代码的更多相关文章

  1. sping整合hibernate之二:dao层开发

     在上一篇日志中将hibernate的会话工厂sessionFactory注入到了spring的容器中,但这样还不够,因为hibernate的增删改查是要使用事务机制的, 所以还要在spring中配置 ...

  2. mybatis generator 自动生成dao层映射代码

    资源: doc url :http://www.mybatis.org/generator/ download:https://github.com/mybatis/generator/release ...

  3. 030医疗项目-模块三:药品供应商目录模块——供货商药品目录查询功能----------Dao层:基本的查询语句的编写

    我们安装显示的要求: 我们能看到显示的目录里面有:供货企业的名字(这个数据来自于供货商的表[usergys]),流水号,通用名,剂型(这些都来自药品信息表),供货的状态(这个呢在gysypml_con ...

  4. DAO 层实现

    一.实验介绍 1.1 实验内容 本节课程主要利用 MyBatis 框架实现 DAO 层. 1.2 实验知识点 MyBatis 框架 MySQL 1.3 实验环境 JDK1.8 Eclipse Java ...

  5. Spring框架之使用JdbcTemplate开发Dao层程序

    简介: JdbcTemplate开发dao层程序     由Spring框架给我们提供,Spring提供的很多操作数据源(关系型数据库,二维表格模型,有明确的行和列(mysql/orcal等) 非关系 ...

  6. 带分页功能的SSH整合,DAO层经典封装

    任何一个封装讲究的是,使用,多状态.Action:     任何一个Action继承分页有关参数类PageManage,自然考虑的到分页效果,我们必须定义下几个分页的参数.并根据这个参数进行查值. 然 ...

  7. 【DRP】-Dao层常用功能代码:增删改查

    本系列博客内容为:做DRP系统中Dao层常用功能. 该项目采用MVC架构 C(Controller)控制器,主要职责;1.取得表单参数:2.调用业务逻辑:3.转向页面 M(Model)模型,主要职责: ...

  8. Java中Action层、Service层、Modle层和Dao层的功能区分

    一.Java中Action层.Service层.Modle层和Dao层的功能区分: 首先,这是现在最基本的分层方式,结合了SSH架构. modle层就是对应的数据库表的实体类.(即domain) Da ...

  9. java中Action层、Service层和Dao层的功能区分

    Action/Service/DAO简介: Action是管理业务(Service)调度和管理跳转的. Service是管理具体的功能的. Action只负责管理,而Service负责实施. DAO只 ...

随机推荐

  1. angular控制器的执行顺序和服务的注入情况

    这篇文章到底要讲什么呢? 这必须要从栗子开始讲起... 看下面这两段代码: demo1: http://jsfiddle.net/ujzmvp3j/1/ demo2: http://jsfiddle. ...

  2. Zookeeper session超时

    1.会话概述 在ZooKeeper中,客户端和服务端建立连接后,会话随之建立,生成一个全局唯一的会话ID(Session ID).服务器和客户端之间维持的是一个长连接,在SESSION_TIMEOUT ...

  3. Lintcode: Majority Number II 解题报告

    Majority Number II 原题链接: http://lintcode.com/en/problem/majority-number-ii/# Given an array of integ ...

  4. idea 提示忽略大小写

  5. Pandas Dataframe增、删、改、查、去重、抽样基本操作

    总括 pandas的索引函数主要有三种: loc 标签索引,行和列的名称 iloc 整型索引(绝对位置索引),绝对意义上的几行几列,起始索引为0 ix 是 iloc 和 loc的合体 at是loc的快 ...

  6. fastjson使用TypeReference示例

    package junit.test; import java.util.ArrayList; import java.util.HashMap; import java.util.List; imp ...

  7. css3 data-attribute属性打造漂亮的按钮

    之前介绍了几款css3实现的按钮,今天为网友来款比较新鲜的,用css3的data-attribute属性开发按钮,当鼠标经过显示按钮的详细信息.而且实现过程很简单,几行代码就搞定.大家试一试吧.如下图 ...

  8. Android 后台发送邮件 (收集应用异常信息+Demo代码)

    上一次说了如何收集我们已经发布的应用程序的错误信息,方便我们调试完善程序.上次说的收集方法主要是把收集的信息通过Http的post请求把相关的异常信息变成请求参数发送到服务器.这个对做过web开发的人 ...

  9. [转]JSTL 与 JSP 或者 Java 相互传递变量的代码

    原文地址:http://blog.csdn.net/joyous/article/details/6689861 两种方式 <c:set var="s1" value=&qu ...

  10. EnumUtil

    EnumUtil.cs using System; using System.Collections.Generic; using System.ComponentModel; using Syste ...