hibernate+pageBean实现分页dao层功能代码
今天闲来无事,摆弄了一下分页,突然发现很多代码长时间不用就生梳了,虽然有些基础,但没有一篇整合的。这里还是简单示例,主要是以后自己翻着看不用百度找啊找找不到一篇想要的
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层功能代码的更多相关文章
- sping整合hibernate之二:dao层开发
在上一篇日志中将hibernate的会话工厂sessionFactory注入到了spring的容器中,但这样还不够,因为hibernate的增删改查是要使用事务机制的, 所以还要在spring中配置 ...
- mybatis generator 自动生成dao层映射代码
资源: doc url :http://www.mybatis.org/generator/ download:https://github.com/mybatis/generator/release ...
- 030医疗项目-模块三:药品供应商目录模块——供货商药品目录查询功能----------Dao层:基本的查询语句的编写
我们安装显示的要求: 我们能看到显示的目录里面有:供货企业的名字(这个数据来自于供货商的表[usergys]),流水号,通用名,剂型(这些都来自药品信息表),供货的状态(这个呢在gysypml_con ...
- DAO 层实现
一.实验介绍 1.1 实验内容 本节课程主要利用 MyBatis 框架实现 DAO 层. 1.2 实验知识点 MyBatis 框架 MySQL 1.3 实验环境 JDK1.8 Eclipse Java ...
- Spring框架之使用JdbcTemplate开发Dao层程序
简介: JdbcTemplate开发dao层程序 由Spring框架给我们提供,Spring提供的很多操作数据源(关系型数据库,二维表格模型,有明确的行和列(mysql/orcal等) 非关系 ...
- 带分页功能的SSH整合,DAO层经典封装
任何一个封装讲究的是,使用,多状态.Action: 任何一个Action继承分页有关参数类PageManage,自然考虑的到分页效果,我们必须定义下几个分页的参数.并根据这个参数进行查值. 然 ...
- 【DRP】-Dao层常用功能代码:增删改查
本系列博客内容为:做DRP系统中Dao层常用功能. 该项目采用MVC架构 C(Controller)控制器,主要职责;1.取得表单参数:2.调用业务逻辑:3.转向页面 M(Model)模型,主要职责: ...
- Java中Action层、Service层、Modle层和Dao层的功能区分
一.Java中Action层.Service层.Modle层和Dao层的功能区分: 首先,这是现在最基本的分层方式,结合了SSH架构. modle层就是对应的数据库表的实体类.(即domain) Da ...
- java中Action层、Service层和Dao层的功能区分
Action/Service/DAO简介: Action是管理业务(Service)调度和管理跳转的. Service是管理具体的功能的. Action只负责管理,而Service负责实施. DAO只 ...
随机推荐
- 解决code::blocks 17.12不能debug的方法
错误提示: You need to specify a debugger program in the debuggers's settings. 解决方法: 在settings->debugg ...
- HTTP 错误 404.13 - Not Found 请求筛选模块被配置为拒绝超过请求内容长度的请求。
问题:HTTP 错误 404.13 - Not Found 请求筛选模块被配置为拒绝超过请求内容长度的请求. 原因:Web 服务器上的请求筛选被配置为拒绝该请求,因为内容长度超过配置的值(IIS 7 ...
- angular-resource版本差异问题
在 AngularJS v1.3.0-beta.14 这个版本里,使用query方法,如果传递进来的数据不是数组,会报错. 在 AngularJS v1.2.18 这个版本里,使用query方法,如果 ...
- 【驱动】USB驱动实例·串口驱动·键盘驱动
Preface USB体系支持多种类型的设备. 在 Linux内核,所有的USB设备都使用 usb_driver结构描述. 对于不同类型的 USB设备,内核使用传统的设备驱动模型建立设备驱动 ...
- Arrays.sort()的底层实现
1.基本类型(以int为例) 源码中的快速排序,主要做了以下几个方面的优化: 1)当待排序的数组中的元素个数较少时,源码中的阀值为7,采用的是插入排序.尽管插入排序的时间复杂度为0(n^2),但是当数 ...
- 在XSLT中输出内容带有CDATA的XML节点
http://www.cnblogs.com/jaxu/archive/2013/03/13/2956904.html **************************************** ...
- js jquery 函数回调
JS 函数回调 $('#btn_update').click(function () { var table_id = $table.bootstrapTable('getSelections')[0 ...
- python dataframe astype 字段类型转换
使用dtype查看dataframe字段类型 print df.dtypes 使用astype实现dataframe字段类型转换 # -*- coding: UTF-8 -*- import pand ...
- Mybatis 返回插入的主键
业务中,会遇到这样的问题,就是感觉返回的主键,插入作为其他表的外键. 那么问题来了,如何去实现,其实方法比较简单,这里就是重点记录下,会出现的误区. 用自动生成sql工具的话,加上下面这句话 < ...
- jquery文字纵向滚动效果(带间隔停留)
<script type="text/javascript"> //文字纵向滚动 $(function() { var $this = $("#quotati ...