分页查询无处不在。使用Hibernate+jsp+HQL进行分页查询。

第一步:编写房屋实体类和House.hbm.xml映射。

/*
* 房屋实体类
*/
public class House {
private int id;//房屋id private HouseType type;//房屋类型
private Users2 user;//用户
private Street street;//街道 private String title;//标题
private String description;//描述
private String fdate;//日期
private String price;//价格
private String contact;//面积
//省略get和set方法
}
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping
package="entity"> <class name="House" table="House">
<id name="id">
<generator class="increment"/>
</id>
<!--外键-->
<many-to-one name="type" column="type_id" cascade="save-update" />
<many-to-one name="user" column="user_id" cascade="save-update" />
<many-to-one name="street" column="street_id" cascade="save-update" />
<property name="title" />
<property name="description" />
<property name="fdate" />
<property name="price" />
<property name="contact" /> </class> </hibernate-mapping>

第二步:编写hibernate.cfg.xml映射

<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> <hibernate-configuration>
<session-factory name="foo">
<!-- 数据库方言 -->
<property name="dialect">
org.hibernate.dialect.OracleDialect
</property>
<!-- 连接数据库Url -->
<property name="hibernate.connection.url">
jdbc:oracle:thin:@localhost:1521:orcl
</property>
<!-- 连接驱动 -->
<property name="hibernate.connection.driver_class">
oracle.jdbc.driver.OracleDriver
</property>
<!-- 用户名 -->
<property name="hibernate.connection.username">epet</property>
<!-- 密码 -->
<property name="hibernate.connection.password">123456</property> <!-- 在控制台打印sql信息 -->
<property name="show_sql">true</property>
<!-- 创建表结构 -->
<property name="hibernate.hbm2ddl.auto">update</property> <!-- 配置映射信息 --> <mapping resource="entity/House.hbm.xml" /> </session-factory>
</hibernate-configuration>

第三步:HibernateUtil+fenye.java分页语句

package com.msit.hibernate.HibernateUtil;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration; public class HibernateUtil { private HibernateUtil(){ }; public static SessionFactory SessionFactory = null; static{
//hibernate
Configuration cf = new Configuration();
cf.configure();
SessionFactory = cf.buildSessionFactory();//DriverManager.getconnection()
//Session session = SessionFactory.openSession();
} public static Session getSession(){ return SessionFactory.openSession();
} public static void closeSession(Session session){
if(session!=null){
session.clear();
}
} }
package Dao;

import java.util.List;

import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.Transaction; import com.msit.hibernate.HibernateUtil.HibernateUtil; import entity.House; /*
* 分页
*/
public class fenye {
//查询所有房屋
public List<House> selecthouse() {
// TODO Auto-generated method stub
Session session = HibernateUtil.getSession();
//开启事物
Transaction tran=session.beginTransaction(); String hql="from House";
Query q=session.createQuery(hql); List<House> list = q.list(); return list; }
//房屋总数除于要分的条数
public int getTotalPages(int count,int pageSize){
int totalpages=0; totalpages=(count%pageSize==0)?(count/pageSize):(count/pageSize+1);
return totalpages; }
//获取房屋总条数
public int getConut(){
Session session = HibernateUtil.getSession();
Transaction tran=session.beginTransaction(); String hql="select count(*) from House";
Query q=session.createQuery(hql);
List list = q.list();
String li=list.get(0).toString();
Integer count=Integer.parseInt(li);
return count;
} public List<House> selechouse(int pageIndex,int pageSize){
// TODO Auto-generated method stub
Session session = HibernateUtil.getSession();
//开启事物
Transaction tran=session.beginTransaction();
String hql="from House";
Query query=session.createQuery(hql);
query.setFirstResult((pageIndex-1)*pageSize);
query.setMaxResults(pageSize);
List<House> result=query.list(); return result;
}
}

jsp页面:

<%
//==============分页===============
//设置新闻显示条数
int pageSize=4;
//实例化
fenye newxw=new fenye();
//获取数据库有多少条数据
int count=newxw.getConut(); //获取页码
String page1=request.getParameter("pageIndex"); //得到具体要分的页
int pag=newxw.getTotalPages(newxw.getConut(),pageSize);
//得到当前页
int pageIndex=0; //判断得到的值是否有值
if(page1==null){
pageIndex=1; //查询 }else{
//把当前页赋值给pageIndex
pageIndex=Integer.parseInt(page1);
//判断当前页是否为最大页
if(pageIndex>pag){
pageIndex=pag;
} } List<House> list=newxw.selechouse(pageIndex,pageSize);
request.setAttribute("list",list); %>
<%
HouseBiz hou=new HouseBizImpl();
List<House> hoi=hou.selecthouse();
request.setAttribute("list",list); %>
<c:forEach var="mind" items="${requestScope.list}"> /
省略
显示数据/ </c:forEach >

<%
//判断当前页是否为末页
if(pageIndex>1){
%>
<LI><a href="list.jsp?pageIndex=<%=1 %>"> 首页</a></LI>
<LI> <a href="list.jsp?pageIndex=<%=pageIndex-1%>"> 上一页 </a></LI>

<%
}
//判断当前页是否为末页
if(pageIndex<pag){
%>
<LI> <a href="list.jsp?pageIndex=<%=pageIndex+1 %>"> 下一页</a></LI>
<LI> <a href="list.jsp?pageIndex=<%=pag%>"> 末页 </a></LI>

<%
}

%>

</UL>

<SPAN
class=total>[<%=pageIndex %>/<%=pag%>]页</SPAN> </DIV></DIV>

您可以通过点击 右下角 的按钮 来对文章内容作出评价, 也可以通过左下方的 关注按钮 来关注我的博客的最新动态。 

如果文章内容对您有帮助, 不要忘记点击右下角的 推荐按钮 来支持一下哦   

如果您对文章内容有任何疑问, 可以通过评论或发邮件的方式联系我: 2276292708@qq.com

如果需要转载,请注明出处,谢谢!!

Java_Web三大框架之Hibernate+jsp+HQL分页查询的更多相关文章

  1. Java_Web三大框架之Hibernate+jsp+selvect+HQL查询数据

    俗话说:"好记性不如烂笔头".本人学习Hibernate也有一个星期了,对Hibernate也有一个初步的了解.下面对Hibernate显示数据做个笔记,使用租房系统的Hibern ...

  2. Java_Web三大框架之Hibernate+jsp+selvect+HQL注册用户

    Hibernate比SQL语句简单多了,代码冗余少,切方便简洁明了.下面用Hibernate+jsp+selvect+HQL来实现注册用户. 第一步:编写用户实体类和Users2.hbm.xml映射. ...

  3. Java_Web三大框架之Hibernate+jsp+selvect+HQL登入验证

    刚开始接触Hibernate有些举手无措,觉得配置信息太多.经过一个星期的适应,Hibernate比sql简单方便多了.下面做一下Hibernate+jsp+selvect+HQL登入验证. 第一步: ...

  4. Java_Web三大框架之Hibernate+HQL语言基础

    12.1 HQL语言基础Hibernate查询语言为HQL(Hibernate Query Language),可以直接使用实体类名及属性.HQL语法类似于SQL,有SQL的关键词如select.fr ...

  5. Java_Web三大框架之Hibernate 入门(一)

    一.Hibernate简介: Hibernate作者——Gavin King Hibernate创始人 < Hibernate in action >作者 EJB 3.0的Entity b ...

  6. Java_Web三大框架之Hibernate操作数据库(三)

    使用Hibernate操作数据库需要七个步骤: (1)读取并解析配置文件 Configuration conf = newConfiguration().configure(); (2)读取并解析映射 ...

  7. Java_Web三大框架之Hibernate增删改查

    下面介绍一下Hibernate的增删改查. 第一步:编写用户实体类以及User.hbm.xml映射 package com.msl.entity; public class User { privat ...

  8. Java_Web三大框架之Hibernate配置文件(二)

    下面介绍一下编写Hibernate的配置文件,使用Hibernate操作数据库. 开始部署:下载需要的jar包               下载Hibernate           Hibernat ...

  9. Java_Web三大框架之Struts2

    今天正式接触Java_Web三大框架之Struts2框架.对于初学者来说,先来了解什么是框架技术: 一.“框架技术”帮我们更快更好地构建程序: 1.是一个应用程序的半成品 2.提供可重用的公共结构 3 ...

随机推荐

  1. 修改PostgreSQL数据库的默认用户postgres的密码

    有时候,忘记了postgresql 安装时默认用户postgres 的密码,怎么办呢? linux shell命令下面输入: sudo -u postgres psql  (这样就可以直接登录进pos ...

  2. PAT Broken Keyboard (20)

    题目描写叙述 On a broken keyboard, some of the keys are worn out. So when you type some sentences, the cha ...

  3. Python3基础(七) I/O操作

    一个程序可以从键盘读取输入,也可以从文件读取输入:而程序的结果可以输出到屏幕上,也可以保存到文件中便于以后使用.本文介绍Python中最基本的I/O函数. 一.控制台I/O 读取键盘输入 内置函数in ...

  4. VC 获取任务栏窗体的句柄

     本文将介绍一个未公开的Win32 API函数:GetTaskmanWindow.利用它对Windows的任务栏进行操作. 这个函数返回拥有任务栏button的窗体句柄. 在微软的MSDN文档中. ...

  5. Android分包MultiDex原理详解

    MultiDex的产生背景 当Android系统安装一个应用的时候,有一步是对Dex进行优化,这个过程有一个专门的工具来处理,叫DexOpt.DexOpt的执行过程是在第一次加载Dex文件的时候执行的 ...

  6. Api基类

    基类 class BaseController extends Controller{ public $outData = ['code'=>0,'msg'=>'ok']; public ...

  7. PCB OD工具破解实例应用

    以下破解Genesis为例,对OD工具使用进行实例讲解 工具简单 介绍下下载地址: OD工具:是一个新的动态追踪工具,将IDA与SoftICE结合起来的思想,Ring 3级调试器, 是为当今最为流行的 ...

  8. 解决UTF-8方法归纳

    1:通过spring配置过滤器解决 <!-- 配置Spring提供的字符编码过滤器 --> <filter> <filter-name>SpringCharacte ...

  9. Akka源码分析-Event Bus

    akka中的EventBus其实是不常用,也最容易被忽略的一个组件. 但如果你深入Cluster的实现就会发现,这个东西其实还挺有用的,而且它是ActorSystem系统中所有事件消息的一个横切面,通 ...

  10. Akka源码分析-Remote-位置透明

    上一篇博客中,我们研究了remote模式下如何发消息给远程actor,其实无论如何,最终都是通过RemoteActorRef来发送消息的.另外官网也明确说明了,ActorRef是可以忽略网络位置的,这 ...