Javaweb查询客户&分页部分代码
pageBean工具类代码(分页工具)
- package com.home.domain;
- import java.util.List;
- /**
- * 分页的JavaBean
- * @author Administrator
- */
- public class PageBean<T> {
- // 当前页
- private int pageCode;
- // 总页数
- // private int totalPage;
- // 总记录数
- private int totalCount;
- // 每页显示的记录条数
- private int pageSize;
- // 每页显示的数据
- private List<T> beanList;
- public int getPageCode() {
- return pageCode;
- }
- public void setPageCode(int pageCode) {
- this.pageCode = pageCode;
- }
- /**
- * 调用getTotalPage() 获取到总页数
- * JavaBean的属性规定:totalPage是JavaBean是属性 ${pageBean.totalPage}
- * @return
- */
- public int getTotalPage() {
- // 计算
- int totalPage = totalCount / pageSize;
- // 说明整除
- if(totalCount % pageSize == 0){
- return totalPage;
- }else{
- return totalPage + 1;
- }
- }
- /*public void setTotalPage(int totalPage) {
- this.totalPage = totalPage;
- }*/
- 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 List<T> getBeanList() {
- return beanList;
- }
- public void setBeanList(List<T> beanList) {
- this.beanList = beanList;
- }
- }
WEB层
- public String findByPage(){
- //调用Service
- DetachedCriteria criteria = DetachedCriteria.forClass(Customer.class);
- //查询
- PageBean<Customer> page = customerService.findByPage(pageCode,pageSize,criteria);
- //压栈
- ValueStack vs = ActionContext.getContext().getValueStack();
- //栈顶 map集合
- vs.set("page", page);
- return "page";
- }
service层
- //分页查询
- @Override
- public PageBean<Customer> findByPage(Integer pageCode, Integer pageSize, DetachedCriteria criteria) {
- return CustomerDao.findByPage(pageCode,pageSize,criteria);
- }
Dao层
- //分页查询
- @Override
- public PageBean<Customer> findByPage(Integer pageCode, Integer pageSize, DetachedCriteria criteria) {
- PageBean<Customer> page = new PageBean<>();
- page.setPageCode(pageCode);
- page.setPageSize(pageSize);
- //先查询总记录数
- criteria.setProjection(Projections.rowCount());
- List<Number> list = (List<Number>) this.getHibernateTemplate().findByCriteria(criteria);
- if (list!=null&&list.size()>0) {
- int totalCount = list.get(0).intValue();
- page.setTotalCount(totalCount);
- }
- //强调 把select count(*)先清空 ,变成select *....
- criteria.setProjection(null);
- //分页查询数据,每页显示的数据
- //Hib..提供的分页查询
- List<Customer> beanList = (List<Customer>)this.getHibernateTemplate().findByCriteria(criteria, (pageCode-1)*pageSize, pageSize);
- page.setBeanList(beanList);
- return page;
- }
前台设置客户数据
- <c:forEach items="${page.beanList }" var="customer">
- <TR
- style="FONT-WEIGHT: normal; FONT-STYLE: normal; BACKGROUND-COLOR: white; TEXT-DECORATION: none">
- <TD>${customer.cust_name }</TD>
- <TD>${customer.level.dict_item_name }</TD>
- <TD>${customer.source.dict_item_name }</TD>
- <TD>${customer.cust_linkman }</TD>
- <TD>${customer.cust_phone }</TD>
- <TD>${customer.cust_mobile }</TD>
- <TD>
- <a href="${pageContext.request.contextPath }/customerServlet?method=edit&custId=${customer.cust_id}">修改</a>
- <a href="${pageContext.request.contextPath }/customerServlet?method=delete&custId=${customer.cust_id}">删除</a>
- </TD>
- </TR>
</c:forEach>
前台设置分页
- <TR>
- <TD><SPAN id=pagelink>
- <DIV
- style="LINE-HEIGHT: 20px; HEIGHT: 20px; TEXT-ALIGN: right">
- 共[<B>${page.totalCount}</B>]条记录,共[<B>${page.totalPage}</B>]页
- ,每页显示
- <select name="pageSize">
- <option value="2" <c:if test="${page.pageSize==2 }">selected</c:if>>2</option>
- <option value="3" <c:if test="${page.pageSize==3 }">selected</c:if>>3</option>
- </select>
- 条
- <c:if test="${page.pageCode>1 }">
- [<A href="javascript:to_page(${page.pageCode-1})">前一页</A>]
- </c:if>
- <B>${page.pageCode}</B>
- <c:if test="${page.pageCode<page.totalPage }">
- [<A href="javascript:to_page(${page.pageCode+1})">后一页</A>]
- </c:if>
- 到
- <input type="text" size="3" id="page" name="pageCode" />
- 页
- <input type="button" value="Go" onclick="to_page()"/>
- </DIV>
- </SPAN></TD>
- </TR>
- to_page()点击事件(Form表单提交到客户Action)
- <SCRIPT language=javascript>
- //提交分页
- function to_page(page){
- if(page){
- $("#page").val(page);
- }
- document.customerForm.submit();
- }
- </SCRIPT>
Javaweb查询客户&分页部分代码的更多相关文章
- ASP.NET MVC搭建项目后台UI框架—6、客户管理(添加、修改、查询、分页)
目录 ASP.NET MVC搭建项目后台UI框架—1.后台主框架 ASP.NET MVC搭建项目后台UI框架—2.菜单特效 ASP.NET MVC搭建项目后台UI框架—3.面板折叠和展开 ASP.NE ...
- MVC客户管理(添加、修改、查询、分页)
ASP.NET MVC搭建项目后台UI框架—6.客户管理(添加.修改.查询.分页) 目录 ASP.NET MVC搭建项目后台UI框架—1.后台主框架 ASP.NET MVC搭建项目后台UI框架—2 ...
- MVC+Bootstrap+Drapper使用PagedList.Mvc支持多查询条件分页
前几天做一个小小小项目,使用了MVC+Bootstrap,以前做分页都是异步加载Mvc部分视图的方式,因为这个是小项目,就随便一点.一般的列表页面,少不了有查询条件,下面分享下Drapper+Page ...
- 【JavaWeb】客户关系管理系统
前言 为了巩固开发的流程,我们再拿一个客户关系管理系统来练手...! 成果图 我们完成的就是下面的项目! 搭建配置环境 配置Tomcat 导入开发包 建立开发用到的程序包 在数据库创建相对应的表 CR ...
- 走向面试之数据库基础:二、SQL进阶之case、子查询、分页、join与视图
一.CASE的两种用法 1.1 等值判断->相当于switch case (1)具体用法模板: CASE expression WHEN value1 THEN returnvalue1 WHE ...
- Web 组合查询加 分页
使用ADO.NET 数据访问技术制作web端组合查询加分页的功能关键在于查询SQL语句的拼接 以Car 表为例 每页显示3条数据 数据访问类使用查询方法,tsql 查询的连接字符串,查询的参数放到Ha ...
- 关于ExtJs4的Grid带 查询 参数 分页(baseParams-->extraParams)
(园里很多文章,美名其曰 :ExtJs GridPanel+查询条件+分页. 但是加查询条件后点击下一页,查询条件失效,求你们自己测试明白再显摆 不要误导我这种新人.) ExtJs6发布了,ExtJ ...
- EF 之 MVC 排序,查询,分页 Sorting, Filtering, and Paging For MVC About EF
最近悟出来一个道理,在这儿分享给大家:学历代表你的过去,能力代表你的现在,学习代表你的将来. 十年河东十年河西,莫欺少年穷 学无止境,精益求精 上篇博客我们学习了EF CodeFirst增删改查 ...
- php分页类代码带分页样式效果(转)
php分页类代码,有漂亮的分页样式风格 时间:2016-03-16 09:16:03来源:网络 导读:不错的php分页类代码,将类文件与分页样式嵌入,实现php查询结果的精美分页,对研究php分页原理 ...
随机推荐
- Python爬虫之关于登录那些事
常见的登录方式有以下两种: 查看登录页面,csrf,cookie;授权:cookie 直接发送post请求,获取cookie 上面只是简单的描述,下面是详细的针对两种登录方式的时候爬虫的处理方法 第一 ...
- Vue环境搭建及node安装过程整理
一.nodejs的安装 Node.js安装包及源码下载地址为:https://nodejs.org/en/download/. 我们可以根据不同平台系统选择你需要的Node.js安装包.Node.js ...
- vue项目在IE下报 [vuex] vuex requires a Promise polyfill in this browser问题
如下图所示,项目在IE11下打开报错: 因为使用了 ES6 中用来传递异步消息的的Promise,而IE浏览器都不支持. 解决方法: 第一步: 安装 babel-polyfill . babel-po ...
- POJ 2304
#include<iostream>// cheng da cai zi 11. 18 解锁问题 using namespace std; #define f 360 int main() ...
- (转)Python 字符串
原文:http://www.runoob.com/python/python-strings.html
- 常用chrome插件&&常用FireFox插件
第一部分:chrome插件 chrome中输入 chrome://chrome-urls/ 可以得到包括缓存在内的很多相关信息. 1.掘金chrome插件 点击下载 掘金是一个高质量的互联网技术 ...
- springboot设置静态资源不拦截的方法
springboot设置静态资源不拦截的方法 springboot不拦截静态资源需配置如下的类: import org.springframework.context.annotation.Confi ...
- Servlet Filter(过滤器)、Filter是如何实现拦截的、Filter开发入门
Servlet Filter(过滤器).Filter是如何实现拦截的.Filter开发入门 Filter简介 Filter也称之为过滤器,它是Servlet技术中最激动人心的技术,WEB开发人员通过F ...
- 使用httpClient连接池处理get或post请求
以前有一个自己写的: http://www.cnblogs.com/wenbronk/p/6482706.html 后来发现一个前辈写的更好的, 再此感谢一下, 确实比我写的那个好用些 1, 创建一个 ...
- 发布Framework 4.0到iis时,出现HTTP 错误 403.14 - Forbidden
新发布MVC到服务器的时候,经常碰到403.14错误,绝大部分的时候都是因为Framework 4.0需要重新注册下,在运行里输入:C:\Windows\Microsoft.NET\Framework ...