专栏首页lgp20151222Struts+Hibernate+jsp页面,实现分页

Struts+Hibernate+jsp页面,实现分页

dao层代码

package com.hanqi.dao;

import java.util.ArrayList;
import java.util.List;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.boot.registry.StandardServiceRegistryBuilder;
import org.hibernate.cfg.Configuration;
import org.hibernate.service.ServiceRegistry;

import com.hanqi.utility.USer;

public class USerDAO 
{
        private Configuration cfg = null ;
        private ServiceRegistry sr = null ;
        
        private SessionFactory sf = null ;
        private Session se = null ;
        Transaction ts = null ;
        
        
        public USerDAO()
        {
            //初始化Hibernate
            cfg = new Configuration().configure() ;
            
            sr = new StandardServiceRegistryBuilder().applySettings(cfg.getProperties()).build() ;
            
        }
        
        public void init()
        {
            sf = cfg.buildSessionFactory(sr) ;
            
            se = sf.openSession() ;
            
            ts = se.beginTransaction() ;
        }
        
        
        public void destory()
        {
            ts.commit() ; 
            
            se.close() ;
            
            sf.close() ; 
        }
        
        
        
        //查询列表
        public List<USer> getAll(int page)
        {
            List<USer> list = new ArrayList<>() ;
            
            init() ;
            
             //设置每页两行及起始页
            list = se.createQuery("from USer").setMaxResults(2)
                        .setFirstResult((page-1)*2).list() ;
            
            destory();
            
            return list;
        }
}

jsp页面

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
<a href="addUSer">添加用户</a>
<br><br>
<a href="selectUSer?pages=1" >用户列表</a>
</body>
</html>
<%@page import="com.hanqi.utility.USer"%>
<%@page import="java.util.List"%>
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
<%

List<USer> list = (List<USer>)request.getAttribute("selectuser") ;

for(USer us : list )
{
    out.print(us + "<a href='deleteuser?user_id="+us.getUser_id()+"'>    【删除】</a>"
                        +"<a href='modify?userid="+us.getUser_id()+"'>    【修改】</a>"
                            +"<br>") ;
}
int pages = Integer.parseInt(request.getParameter("pages")) ;

%>

<% if(list.size()==0){response.getWriter().write("页码超出范围") ;
                                response.setHeader("refresh", "3;url=selectUSer?pages=1") ;}else{ %>
<%%>
<a href="selectUSer?pages=<%=pages-1%>">上一页</a>
<a href="selectUSer?pages=<%=pages+1%>">下一页</a>
<%} %>
</body>
</html>

Struts文件配置

<!-- 查询全部 -->
        <action name="selectUSer" class="com.hanqi.action.USerAction" method="selectUSer">
        
                <result name="fail">/WEB-INF/pages/fail.jsp</result>
        
                <result name="success">/WEB-INF/pages/selectUSer.jsp</result>
        
        </action>

 service层方法

public String selectUSer()
    {
        String rtn = "fail" ;
        
        try
        {//得到原生request
            HttpServletRequest hsr = ServletActionContext.getRequest() ;
            
            int page = Integer.parseInt(hsr.getParameter("pages")) ;
            
            //page = Integer.parseInt(hsr.getParameter("pagess")) ;
            //调用查询的方法
            List<USer> list = new UserService().getAll(page);
            
            hsr.setAttribute("pages", page+1);
            
            hsr.setAttribute("selectuser", list);
        
            rtn = "success" ;
        }catch(Exception e)
        {
            e.printStackTrace();
        }
        
        return rtn;
    }

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 儿童创造力教育与编程教育的碰撞——MIT雷斯尼克教授最新理论梗概

    儿童编程教育已经在我国各一线二线城市疯狂出现,颇有“烂大街”的趋势。我们不禁要问很多很多问题:

    一石匠人
  • 《动物魔法学校》儿童学编程Scratch之“外观”部分

    导读:本文通过一个案例《动物魔法学校》来学习Scratch语言的“外观”部分。之后通过一系列其他功能的综合运用对作品功能进行了扩展。

    一石匠人
  • 声音功能让儿童编程更有创造性

    导读:Scratch中声音功能非常强大,除了常规的音效,你甚至可以模拟各种乐器的各个发音、设置节拍、休止……如果你愿意,甚至可以用它创作一个交响乐。我们可以引导...

    一石匠人
  • SQL中GROUP BY用法示例

    GROUP BY我们可以先从字面上来理解,GROUP表示分组,BY后面写字段名,就表示根据哪个字段进行分组,如果有用Excel比较多的话,GROUP BY比较类...

    Awesome_Tang
  • 【系统设置】CentOS 修改机器名

    ken.io
  • 天干地支五行八卦的对应关系

    一石匠人
  • 什么样的人生才是有意义的人生——没有标准的标准答案

    【导读】其实我们可以跳出这个小圈圈去更加科客观地看一下这个世界。在夜晚的时候我们仰望天空,浩瀚的宇宙中整个地球只是一粒浮尘,何况地球上一个小小的人类?在漫长的历...

    一石匠人
  • 复杂业务下向Mysql导入30万条数据代码优化的踩坑记录

    从毕业到现在第一次接触到超过30万条数据导入MySQL的场景(有点low),就是在顺丰公司接入我司EMM产品时需要将AD中的员工数据导入MySQL中,因此楼主负...

    haifeiWu
  • 一张图理清《梅花易数》梗概

    学《易经》的目的不一定是为了卜卦,但是了解卜卦绝对能够让你更好地了解易学。今天用一张思维导图对《梅花易数》的主要内容进行概括,希望能够给学友们提供帮助。

    一石匠人
  • 我不是算命先生,却对占卜有了疑惑——如何论证“占卜前提”的正确与否

    事出有因,我对《周易》感兴趣了很多年。只是觉得特别有趣,断断续续学习了一些皮毛。这几天又偶然接触到了《梅花易数》,觉得很是精彩,将五行八卦天干地支都串联了起来。...

    一石匠人

扫码关注云+社区

领取腾讯云代金券