springJDBC实现mysql简单分页
效果图:
aaarticlea/png;base64,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" alt="" />
前台jsp代码如下:
<div class="listNav">
<div class="instruction">
您正在查看${result }个结果中的第${start+1 }-${limit }项结果。
</div>
<fieldset><legend>首页</legend>
<input type="button" name="eventSubmit_doList_first" onclick="javascript:window.location.href='${pageContext.request.contextPath}/cw/allSiteCourse.do?start=0&limit=${limit}'" value="|<">
</fieldset>
<fieldset><legend>前一页</legend>
<input type="button" name="eventSubmit_doList_prev" onclick="javascript:window.location.href='${pageContext.request.contextPath}/cw/allSiteCourse.do?start=${start-limit }&limit=${limit}'" value="<">
</fieldset>
<select name="selectPageSize" id="selectPageSize" onchange="changePager(this.value)">
<option value="5">显示5项…</option>
<option value="10">显示10项…</option>
<option value="20" selected>显示20项…</option>
<option value="50">显示50项…</option>
<option value="100">显示100项…</option>
<option value="200">显示200项…</option>
<fieldset><legend>后一页</legend>
<input type="button" name="eventSubmit_doList_next" onclick="javascript:window.location.href='${pageContext.request.contextPath}/cw/allSiteCourse.do?start=${start+limit }&limit=${limit}'" value=">">
</fieldset>
<fieldset><legend>尾页</legend>
<input type="button" name="eventSubmit_doList_last" onclick="javascript:window.location.href='${pageContext.request.contextPath}/cw/allSiteCourse.do?start=${result }&limit=${limit}'" value=">|">
</fieldset>
</div>
controller如下:
@RequestMapping(value="/allSiteCourse",method=RequestMethod.GET)
public String allSiteCourse(HttpServletRequest request,Pager pager){
//查询数据库中所有的条数
int result = cwInfoService.queryAllSitesCount();
//设置分页
pager = cwInfoService.setPage(pager, result);
List<Sites> siteList = cwInfoService.queryAllSites(pager);
request.setAttribute("siteList", siteList);
request.setAttribute("start", pager.getStart());
request.setAttribute("limit", pager.getLimit());
request.setAttribute("result", result);
return "/jsp/coursewareSelectAllSites";
}
service,以及实现类如下:
/**
* 描述:查询出所有的站点总共有多少个
* @return
*/
int queryAllSitesCount();
/**
* 描述:设置分页的起始条数
* @param pager
* @return
*/
Pager setPage(Pager pager,int result);
@Override
public int queryAllSitesCount() {
return cwInfoDao.queryAllSitesCount();
} @Override
public Pager setPage(Pager pager,int result) {
//总共多少页
int pageCount = 0;
//最后一页的起始条数
int lastStart = 0;
if(pager.getLimit()!=null){
//根据余数判断最后一页是否是满
if(result%pager.getLimit()==0){
//计算出当前数据总共有多少页
pageCount = result/pager.getLimit();
//当前页数小于一页
if(pageCount<=1){
lastStart = 0;
}else{
lastStart = result-pager.getLimit();
}
}else{
pageCount = (result/pager.getLimit())+1;
if(pageCount<=1){
lastStart = 0;
}else{
lastStart = (pageCount-1)*pager.getLimit();
}
}
}
//设置分页
if(!(pager.getStart()!=null&&pager.getLimit()!=null)){
pager.setStart(0);
pager.setLimit(20);
//前一页出现负值情况
}else if(pager.getStart()<0){
pager.setStart(0);
//当前页的数据不够一页
}else if(result-pager.getLimit()<0){
pager.setStart(0);
//下一页出现超出数据情况
}else if(pager.getStart()>=result){
pager.setStart(lastStart);
}
return pager;
}
dao以及底层springJDBC:
/**
* 描述:查询所有的站点信息
* @return
*/
List<Sites> queryAllSites(Pager pager);
/**
* 描述:查询出所有的站点总共有多少个
* @return
*/
int queryAllSitesCount();
@Override
public List<Sites> queryAllSites(Pager pager) {
String sql = "select * from sakai_site order by SITE_ID limit ?,?";
Object[] obj = new Object[]{pager.getStart(),pager.getLimit()};
List<Sites> list = jdbcTemplate.query(sql,obj, new siteMapper());
return list;
}
@Override
public int queryAllSitesCount() {
String sql = "select count(*) from sakai_site";
int result = jdbcTemplate.queryForObject(sql,Integer.class);
return result;
}
class siteMapper implements RowMapper<Sites>{ @Override
public Sites mapRow(ResultSet rs, int rowNum) throws SQLException {
Sites site = new Sites();
site.setCreatedby(rs.getString("CREATEDBY"));
site.setCreatedon(rs.getDate("CREATEDON"));
site.setCustomPageOrdered(rs.getString("CUSTOM_PAGE_ORDERED"));
site.setDescription(rs.getString("DESCRIPTION"));
site.setIconUrl(rs.getString("ICON_URL"));
site.setInfoUrl(rs.getString("INFO_URL"));
site.setIsSoftlyDeleted(rs.getString("IS_SOFTLY_DELETED"));
site.setIsSpecial(rs.getString("IS_SPECIAL"));
site.setIsUser(rs.getString("IS_USER"));
site.setJoinable(rs.getString("JOINABLE"));
site.setJoinRole(rs.getString("JOIN_ROLE"));
site.setModifiedby(rs.getString("MODIFIEDBY"));
site.setModifiedon(rs.getDate("MODIFIEDON"));
site.setPublished(rs.getInt("PUBLISHED"));
site.setPubview(rs.getString("PUBVIEW"));
site.setShortDesc(rs.getString("SHORT_DESC"));
site.setSiteId(rs.getString("SITE_ID"));
site.setSkin(rs.getString("SKIN"));
site.setSoftlyDeletedDate(rs.getDate("SOFTLY_DELETED_DATE"));
site.setTitle(rs.getString("TITLE"));
site.setType(rs.getString("TYPE"));
return site;
}
}
还有一个简短的js:
//分页
function changePager(obj){
window.location.href=ctx + "/cw/allSiteCourse.do?start=0&limit="+obj;
}
$(document).ready(function(){
if(limit!=''){
$('option[value='+limit+']').attr('selected',true);
}
});
springJDBC实现mysql简单分页的更多相关文章
- MyBatis+mysql 简单分页
注意:limit不能跟动态内容 <select id="fenYe" parameterType="int" resultType="com.x ...
- MySql简单分页存储过程
BEGIN DECLARE startIndex int; select COUNT(*) INTO RecordCount from test; SET startIndex = (PageInde ...
- 简单的PHP+Mysql实现分页
<?php /** * PHP+Mysql实现分页 * **/ ?> <html> <head> <meta http-equiv="Content ...
- Mysql中分页查询两个方法比较
mysql中分页查询有两种方式, 一种是使用COUNT(*)的方式,具体代码如下 1 2 3 SELECT COUNT(*) FROM foo WHERE b = 1; SELECT a FROM ...
- MySQL高效分页-mybatis插件PageHelper改进
MySQL分页在表比较大的时候,分页就会出现性能问题,MySQL的分页逻辑如下:比如select * from user limit 100000,10 它是先执行select * from user ...
- Oracle和MySql的分页查询区别和PL/SQL的基本概念
Oracle和MySql的分页查询区别: Oracle的分析查询,之前Oracle的分页是使用伪列 ROWNUM 结合子查询实现,mysql的分页更简单,直接使用 LIMIT 关键字就可以实现 ...
- mysql 深度分页
mysql 分页查询使我们常见的需求 ,但是随着页数的增加查询性能会逐渐下降,尤其是到深度分页的情况.我们可以把分页分为两个步骤,1.定位偏移量,2.获取分页条数的 数据. 所以当数据较大页数较深时 ...
- JavaScript简单分页,兼容IE6,~3KB
简介 兼容IE6+及现代浏览器的简单分页,支持同一页面多个分页. 使用 Browser <link rel="stylesheet" href="css/GB-pa ...
- MySQL的分页优化
今天下午,帮同事重写了一个MySQL SQL语句,该SQL语句涉及两张表,其中一张表是字典表(需返回一个字段),另一张表是业务表(本身就有150个字段,需全部返回),当然,字段的个数是否合理在这里不予 ...
随机推荐
- 进化策略-python实现
ESIndividual.py import numpy as np import ObjFunction class ESIndividual: ''' individual of evolutio ...
- 如何使用lessc编译.less文件
LESS :一种动态样式语言. LESS 将 CSS 赋予了动态语言的特性,如 变量, 继承, 运算, 函数. LESS 既可以在 客户端 上运行 (支持IE 6+, Webkit, Firefox) ...
- USACO 3.2 ratios 高斯消元
题目原意很简单,就是解一个三元一次方程组 直接高斯消元解方程组,枚举最后一列的倍数(k) 注意double的精度,有很多细节需要处理 /* PROB:ratios LANG:C++ */ #inclu ...
- Uva11134 Fabled Rooks
普通的贪心题. 虽然图是二维的,但可以把横向和纵向分开处理. 将区间按右端点排序,然后从区间左端点到右端点找第一个空位置放棋子即可. /*by SilverN*/ #include<algori ...
- Aho-Corasick算法、多模正则匹配、Snort入门学习
希望解决的问题 . 在一些高流量.高IO的WAF中,是如何对规则库(POST.GET)中的字符串进行多正则匹配的,是单条轮询执行,还是多模式并发执行 . Snort是怎么组织.匹配高达上千条的正则规则 ...
- PHP函数篇详解十进制、二进制、八进制和十六进制转换函数说明
PHP函数篇详解十进制.二进制.八进制和十六进制转换函数说明 作者: 字体:[增加 减小] 类型:转载 中文字符编码研究系列第一期,PHP函数篇详解十进制.二进制.八进制和十六进制互相转换函数说明 ...
- 本地与在线图片转Base64及图片预览
查看效果:http://sandbox.runjs.cn/show/tgvbo9nq 本地图片转Base64(从而可以预览图片): function localImgLoad() { var src ...
- fork Bomb
类Unix ;(){:|:&};: windows %0|%0
- sockaddr & sockaddr_in struct
struct sockaddr { unsigned short sa_family; /* address family, AF_xxx */ ]; /* 14 bytes of protocol ...
- rwsr-sr-x类似权限设置
如何设置suid/guid? 如果希望设置suid,那么就将相应的权限位之前的那一位设置为4:如果希望设置guid,那么就将相应的权限位之前的那一位设置为2:如果希望两者都置位,那么将相应的权限位之前 ...