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

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

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

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

  1. <!DOCTYPE hibernate-configuration PUBLIC
  2. "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
  3. "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
  4.  
  5. <hibernate-configuration>
  6. <session-factory name="foo">
  7. <!-- 数据库方言 -->
  8. <property name="dialect">
  9. org.hibernate.dialect.OracleDialect
  10. </property>
  11. <!-- 连接数据库Url -->
  12. <property name="hibernate.connection.url">
  13. jdbc:oracle:thin:@localhost:1521:orcl
  14. </property>
  15. <!-- 连接驱动 -->
  16. <property name="hibernate.connection.driver_class">
  17. oracle.jdbc.driver.OracleDriver
  18. </property>
  19. <!-- 用户名 -->
  20. <property name="hibernate.connection.username">epet</property>
  21. <!-- 密码 -->
  22. <property name="hibernate.connection.password">123456</property>
  23.  
  24. <!-- 在控制台打印sql信息 -->
  25. <property name="show_sql">true</property>
  26. <!-- 创建表结构 -->
  27. <property name="hibernate.hbm2ddl.auto">update</property>
  28.  
  29. <!-- 配置映射信息 -->
  30.  
  31. <mapping resource="entity/House.hbm.xml" />
  32.  
  33. </session-factory>
  34. </hibernate-configuration>

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

  1. package com.msit.hibernate.HibernateUtil;
  2.  
  3. import org.hibernate.Session;
  4. import org.hibernate.SessionFactory;
  5. import org.hibernate.cfg.Configuration;
  6.  
  7. public class HibernateUtil {
  8.  
  9. private HibernateUtil(){
  10.  
  11. };
  12.  
  13. public static SessionFactory SessionFactory = null;
  14.  
  15. static{
  16. //hibernate
  17. Configuration cf = new Configuration();
  18. cf.configure();
  19. SessionFactory = cf.buildSessionFactory();//DriverManager.getconnection()
  20. //Session session = SessionFactory.openSession();
  21. }
  22.  
  23. public static Session getSession(){
  24.  
  25. return SessionFactory.openSession();
  26. }
  27.  
  28. public static void closeSession(Session session){
  29. if(session!=null){
  30. session.clear();
  31. }
  32. }
  33.  
  34. }
  1. package Dao;
  2.  
  3. import java.util.List;
  4.  
  5. import org.hibernate.Query;
  6. import org.hibernate.Session;
  7. import org.hibernate.Transaction;
  8.  
  9. import com.msit.hibernate.HibernateUtil.HibernateUtil;
  10.  
  11. import entity.House;
  12.  
  13. /*
  14. * 分页
  15. */
  16. public class fenye {
  17. //查询所有房屋
  18. public List<House> selecthouse() {
  19. // TODO Auto-generated method stub
  20. Session session = HibernateUtil.getSession();
  21. //开启事物
  22. Transaction tran=session.beginTransaction();
  23.  
  24. String hql="from House";
  25. Query q=session.createQuery(hql);
  26.  
  27. List<House> list = q.list();
  28.  
  29. return list;
  30.  
  31. }
  32. //房屋总数除于要分的条数
  33. public int getTotalPages(int count,int pageSize){
  34. int totalpages=0;
  35.  
  36. totalpages=(count%pageSize==0)?(count/pageSize):(count/pageSize+1);
  37. return totalpages;
  38.  
  39. }
  40. //获取房屋总条数
  41. public int getConut(){
  42. Session session = HibernateUtil.getSession();
  43. Transaction tran=session.beginTransaction();
  44.  
  45. String hql="select count(*) from House";
  46. Query q=session.createQuery(hql);
  47. List list = q.list();
  48. String li=list.get(0).toString();
  49. Integer count=Integer.parseInt(li);
  50. return count;
  51. }
  52.  
  53. public List<House> selechouse(int pageIndex,int pageSize){
  54. // TODO Auto-generated method stub
  55. Session session = HibernateUtil.getSession();
  56. //开启事物
  57. Transaction tran=session.beginTransaction();
  58. String hql="from House";
  59. Query query=session.createQuery(hql);
  60. query.setFirstResult((pageIndex-1)*pageSize);
  61. query.setMaxResults(pageSize);
  62. List<House> result=query.list();
  63.  
  64. return result;
  65. }
  66. }

jsp页面:

  1. <%
  2. //==============分页===============
  3. //设置新闻显示条数
  4. int pageSize=4;
  5. //实例化
  6. fenye newxw=new fenye();
  7. //获取数据库有多少条数据
  8. int count=newxw.getConut();
  9. //获取页码
  10. String page1=request.getParameter("pageIndex");
  11. //得到具体要分的页
  12. int pag=newxw.getTotalPages(newxw.getConut(),pageSize);
  13. //得到当前页
  14. int pageIndex=0;
  15. //判断得到的值是否有值
  16. if(page1==null){
  17. pageIndex=1;
  18. //查询
  19. }else{
  20. //把当前页赋值给pageIndex
  21. pageIndex=Integer.parseInt(page1);
  22. //判断当前页是否为最大页
  23. if(pageIndex>pag){
  24. pageIndex=pag;
  25. }
  26. }
  27. List<House> list=newxw.selechouse(pageIndex,pageSize);
  28. request.setAttribute("list",list);
  29. %>
  30. <%
  31. HouseBiz hou=new HouseBizImpl();
  32. List<House> hoi=hou.selecthouse();
  33. request.setAttribute("list",list);
  34. %>
    <c:forEach var="mind" items="${requestScope.list}">
  35. /
    省略
    显示数据/
  36. </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>

  1. 您可以通过点击 右下角 的按钮 来对文章内容作出评价, 也可以通过左下方的 关注按钮 来关注我的博客的最新动态。
  2.  
  3. 如果文章内容对您有帮助, 不要忘记点击右下角的 推荐按钮 来支持一下哦
  4.  
  5. 如果您对文章内容有任何疑问, 可以通过评论或发邮件的方式联系我: 2276292708@qq.com
  6.  
  7. 如果需要转载,请注明出处,谢谢!!

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. ZOJ——3609 Modular Inverse

    Modular Inverse Time Limit: 2 Seconds      Memory Limit: 65536 KB The modular modular multiplicative ...

  2. srvctl error

    Hit an strange error just now. [oracle@racnode1 ~]$ srvctl # # An unexpected error has been detected ...

  3. nodejs fs.open

    fs.open(path, flags, [mode], [callback(err, fd)])是 POSIX open 函数的封装,与 C 语言标准库中的 fopen 函数类似.它接受两个必选参数 ...

  4. BEGINNING SHAREPOINT&#174; 2013 DEVELOPMENT 第12章节--SP 2013中远程Event Receivers

    BEGINNING SHAREPOINT® 2013 DEVELOPMENT 第12章节--SP 2013中远程Event Receivers         本章中,你讲学到: 了解远程evernt ...

  5. zoj 1880 - Tug of War

    题目:有n个人分成两组,两组人数差不能超过1,找到两组的人重量之差的最小值. 分析:dp,二维01背包. 由于必须放在两个组中的一组,直接背包全部可到状态, 取出相差不超过 1的最接近 sum/2的值 ...

  6. HDU 1973

    Prime Path Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total ...

  7. DetachedCriteria的使用

    设计上能够灵活的依据 Criteria 的特点来方便地进行查询条件的组装.如今对 Hibernate的Criteria 的使用方法进行总结:    Hibernate 设计了 CriteriaSpec ...

  8. LeetCode 21. Merge Two Sorted Lists (合并两个有序链表)

    Merge two sorted linked lists and return it as a new list. The new list should be made by splicing t ...

  9. mySql学习笔记:比sql server书写要简单

    在学mySql.总的感觉,mySql与Sql Server差不多,语法都很象,但mySql也许是吸取了SQL SERVER的一些经验,SQL语句书写起来更加简单. 比如说,设置主键.索引,SQL SE ...

  10. java 多线程——并发编程模型 学习笔记

                                                                                                 并发编程模型 ...