package cn.tsjinrong.fastfile.util;





/**

 * @ClassName: Page

 * @Description: TODO(分页组件的父类,用来封装分页的 通用内容和逻辑)

 * @author zhanghaiyang

 * @date 2016年1月14日 下午12:37:55

 * @Copyright © 2016上海通善互联网金融信息服务有限公司

 */

public class Page {





// 用户输入的分页条件

private int currentPage = 1; // 当前页

private int pageSize = 15; // 每页最大行数





// 用于实现分页SQL的条件,是根据用户输入条件计算而来的

private int begin;

private int end;





// 自动计算出的总行数

private int rows;

// 根据总行数计算总页数,然后将总页数输出给页面

private int totalPage;





public int getRows() {

return rows;

}





public void setRows(int rows) {

this.rows = rows;

}





public int getTotalPage() {

// 根据总行数,计算总页数

if (rows % pageSize == 0) {

totalPage = rows / pageSize;

} else {

totalPage = rows / pageSize + 1;

}

return totalPage;

}





public void setTotalPage(int totalPage) {

this.totalPage = totalPage;

}





public int getBegin() {

// 在mapper.xml使用begin属性时,对其进行计算

begin = (currentPage - 1) * pageSize;

return begin;

}





public void setBegin(int begin) {

this.begin = begin;

}





public int getEnd() {

// 在mapper.xml使用end属性时,对其进行计算

end = currentPage * pageSize + 1;

return end;

}





public void setEnd(int end) {

this.end = end;

}





public int getCurrentPage() {

return currentPage;

}





public void setCurrentPage(int currentPage) {

this.currentPage = currentPage;

}





public int getPageSize() {

return pageSize;

}





public void setPageSize(int pageSize) {

this.pageSize = pageSize;

}





}



public ModelAndView findVideosByPage(HttpServletRequest request, HttpServletResponse response, FileProperties fp) {





ModelAndView model = new ModelAndView("/video/video_list");

Map<String, Object> params = new HashMap<String, Object>(3);

if (StringUtils.isNotBlank(fp.getBusiId())) {

params.put("busiId", fp.getBusiId());

}

if (StringUtils.isNotBlank(fp.getApplyName())) {

params.put("applyName", fp.getApplyName());

}

if (fp.getApplyDateStart() != null && StringUtils.isNotBlank(fp.getApplyDateStart())) {

params.put("applyDateStart", DateUtil.parseDate(fp.getApplyDateStart()));

} else {

params.put("applyDateStart", DateUtil.addDay(new Date(), -7));

}

if (fp.getApplyDateEnd() != null && StringUtils.isNotBlank(fp.getApplyDateEnd())) {

params.put("applyDateEnd", DateUtil.parseDate(fp.getApplyDateEnd()));

} else {

params.put("applyDateEnd", DateUtil.format(new Date()));

}

fp.setRows(fastfileVideoService.selectRows(params));

model.addObject("fastfileVideoInfoPage", fp);

List<FastfileVideoInfo> fastfileVideoInfos = fastfileVideoService.selectByPage(fp);

model.addObject("fastfileVideoInfos", fastfileVideoInfos);

model.addObject("applyDateStart", DateUtil.format(DateUtil.addDay(new Date(), -7)));

model.addObject("applyDateEnd", DateUtil.format(new Date()));

return model;

}



<select id="selectByPage" resultMap="BaseResultMap" parameterType="cn.tsjinrong.fastfile.util.FileProperties">

select

<include refid="Base_Column_List" />

from fastfile_video_info where 1=1

<if test="busiId != null and busiId !=''">

and busi_id = #{busiId,jdbcType=VARCHAR}

</if>

<if test="applyName != null and applyName !=''">

and apply_name=#{applyName,jdbcType=VARCHAR}

</if>

<if test="applyDateStart != null and applyDateStart !=''">

and apply_date &gt;= #{applyDateStart,jdbcType=DATE}

</if>

<if test="applyDateEnd != null and applyDateEnd !=''">

and apply_date &lt;= #{applyDateEnd,jdbcType=DATE}

</if>

and del_flag = 0

order by apply_date desc limit #{beginRow},#{pageSize}

</select>

MyBatis学习总结(12)——Mybatis+Mysql分页查询的更多相关文章

  1. MyBatis学习总结(七)——Mybatis缓存(转载)

      孤傲苍狼 只为成功找方法,不为失败找借口! MyBatis学习总结(七)--Mybatis缓存 一.MyBatis缓存介绍 正如大多数持久层框架一样,MyBatis 同样提供了一级缓存和二级缓存的 ...

  2. 【转】MyBatis学习总结(一)——MyBatis快速入门

    [转]MyBatis学习总结(一)——MyBatis快速入门 一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC ...

  3. 【转】MyBatis学习总结(七)——Mybatis缓存

    [转]MyBatis学习总结(七)——Mybatis缓存 一.MyBatis缓存介绍 正如大多数持久层框架一样,MyBatis 同样提供了一级缓存和二级缓存的支持 一级缓存: 基于PerpetualC ...

  4. 转:MyBatis学习总结(Mybatis总结精华文章)

    http://www.cnblogs.com/xdp-gacl/tag/MyBatis%E5%AD%A6%E4%B9%A0%E6%80%BB%E7%BB%93/ 当前标签: MyBatis学习总结   ...

  5. Mybatis学习系列(五)关联查询

    前面几节的示例基本都是一些单表查询,实际项目中,经常用到关联表的查询,比如一对一,一对多等情况.在Java实体对象中,一对一和一对多可是使用包装对象解决,属性使用List或者Set来实现,在mybat ...

  6. Mybatis学习笔记12 - 动态sql之choose(when otherwise)标签

    choose (when, otherwise):分支选择:带了break的swtich-case 示例代码: 接口定义: package com.mybatis.dao; import com.my ...

  7. MyBatis 学习记录5 MyBatis的二级缓存

    主题 之前学习了一下MyBatis的一级缓存,主要涉及到BaseExecutor这个类. 现在准备学习记录下MyBatis二级缓存. 配置二级缓存与初始化发生的事情 首先二级缓存默认是不开启的,需要自 ...

  8. MyBatis学习总结(一)——MyBatis快速入门(转载)

    本文转载自http://www.cnblogs.com/jpf-java/p/6013537.html MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了 ...

  9. MyBatis学习总结(一)——MyBatis快速入门

    一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以 ...

  10. MyBatis学习笔记(一)——MyBatis快速入门

    转自孤傲苍狼的博客:http://www.cnblogs.com/xdp-gacl/p/4261895.html 一.Mybatis介绍 MyBatis是一个支持普通SQL查询,存储过程和高级映射的优 ...

随机推荐

  1. linux 下的select函数

    函数原型 /* According to POSIX.1-2001 */ #include <sys/select.h>  //头文件 /* According to earlier st ...

  2. BZOJ5105: [CodePlus2017]晨跑

    [传送门:BZOJ5105] 简要题意: 给出a,b,c,求a,b,c的最小公倍数 题解: 直接搞(最近刷水题有点心态爆炸) 参考代码: #include<cstdio> #include ...

  3. html2canvas截取页面

    1.下载html2canvas.js 2.引入 3.修改html2canvas支持远程图片处理 function ImageContainer(src, cors) { this.src = src; ...

  4. 定时器函数SetTimer

    原文链接:http://www.cnblogs.com/zhangpengshou/archive/2009/04/05/1429770.html 一.SetTimer表示的是定义个定时器.根据定义指 ...

  5. BZOJ2668: [cqoi2012]交换棋子(费用流)

    Description 有一个n行m列的黑白棋盘,你每次可以交换两个相邻格子(相邻是指有公共边或公共顶点)中的棋子,最终达到目标状态.要求第i行第j列的格子只能参与mi,j次交换. Input 第一行 ...

  6. vue踩坑- 报错npm ERR! cb() never called!

    在vue项目中引入饿了么elementUI组件的步骤之中,出现以下的错误: D:\my-project-first>npm i element-ui -S Unhandled rejection ...

  7. 【Henu ACM Round#15 C】 A and B and Team Training

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 枚举第一种方法. 剩下的全都个第二种方法. 看看能组成多少个队伍就可以了. [代码] #include <bits/stdc+ ...

  8. SQL 自增列清零方法

    SQL Identity自增列清零方法1.使用DBCC控制台命令: dbcc checkident(表名,RESEED,0) 2.truncate table 也可将当前标识值清零 但当有外键等约束时 ...

  9. jni中调用java方法获取当前apk的签名文件md5值

    相应的java方法: void getsign(Context context) throws Exception { PackageInfo localPackageInfo = context.g ...

  10. easyui datagird 总计栏

    在使用easyui 的表格的时.非常多时候须要加一个总计栏,当然easyui中有加总计栏的方法,写一个footer就好,然而我认为这样的方法并不好.由于加入的总计栏是和列表每一个单元格相应的,有长度限 ...