分页简单的封装SSM+easyUi
public class Page {
private int page = 1; //初始页
private int rows = 10; //一页多少行数据
private String q;// 要查询的 关键字
private String order = "asc";// 是'asc'或'desc'
protected String sort = "d.id";// 那个字段进行排序 public int getBegin() {
return (page - 1) * rows;
} public int getEnd() {
return rows;
}
// 上面4个属性给mapper使用,limit,order里面使用 public int getPage() {
return page;
} public void setPage(int page) {
this.page = page;
} public int getRows() {
return rows;
} public void setRows(int rows) {
this.rows = rows;
} public String getQ() {
return q;
} public void setQ(String q) {
this.q = q;
} public String getOrder() {
return order;
} public void setOrder(String order) {
this.order = order;
} public String getSort() {
return sort;
} public void setSort(String sort) {
this.sort = sort;
}
}
定义一个page类,简单的处理一哈,这个应该都看得懂,很简单
这个PageMapper就是Dao接口里面的 定义一个泛型,方便封装,其余的类想用分页直接继承,改一下类型
public interface PageMapper<T> { Integer findCountByQuery(Query query); //查询的行数 List<T> findLimitByQuery(Query query); //模糊查询
}
下面就贴一下xml文件的 代码,就是写的sql 映射这一些,现在开发都用的映射,写xml配置,以前是用的注解,不会的度娘吧
下面
StudentQuery里面的定义就看自己的需求,get、set方法,这个会不 继承上面的pege就好了
<!-- 根据条件查询count -->
<!-- findCountByQuery 方法名 dao接口的两个 这个是查询的行数 parameterType就是返回 -->
<select id="findCountByQuery" resultType="int" parameterType="StudentQuery">
select count(id) from t_student
<!--用的包含-->
<include refid="whereSql" />
</select> <!-- 根据条件查询limit -->
<!--里面的跟上面差不多 只是id要对应方法名哦-->
<select id="findLimitByQuery" resultType="Student"
parameterType="StudentQuery">
select id,name,teacher from
t_student
<include refid="whereSql" /> limit #{begin},#{end}
</select> <!-- 公共的查询条件 根据name模糊查询 当然了 支持多个查询,在后面if就行了跟着这个写 -->
<sql id="whereSql">
<where>
<if test="name!=null and name!=''">
and name like name('%',#{name},'%')
</if>
</where>
</sql>
下面就是service和实现类的
public interface PageService<T> { /**
* 分页
* @param query
* @return
*/
PageList findByQuery(Query query); }
public abstract class BaseServiceImpl<T> implements IBaseService<T> {
@Autowired
BaseMapper<T> baseMapper; @Override
public PageList findByQuery(Query query) {
PageList pageList = new PageList();
Integer count = baseMapper.findCountByQuery(query);
if (count == null || count == 0) {
return pageList;
}
List<T> rows = baseMapper.findLimitByQuery(query);
pageList.setRows(rows);
pageList.setTotal(count);
return pageList;
}
}
好了 最后只需要调用service的方法就搞定了
controller里面直接调用方法返回给前端json数据就好了
注意一点,
StudentQuery 是个人自己定义的 只需要继承pege类就好了 里面就是模糊查询的参数, 这个
PageList 就可以改变的哈 我是用这个类来表示的 当然 你可以换成二维数组 分页查询的数据默认查询全部 丢到前端的就是pagelist 学会变通一下 前端的就不写了 本人是写后台的 没看懂的可以留言
import java.util.ArrayList;
import java.util.List; public class PageList {
private int total; //多少行
private List rows = new ArrayList(); //显示的数据存到集合里面 public int getTotal() {
return total;
} public void setTotal(int total) {
this.total = total;
} public List getRows() {
return rows;
} public void setRows(List rows) {
this.rows = rows;
} @Override
public String toString() {
return "PageList [total=" + total + ", rows=" + rows + "]";
} }
/**
* controller
*
* @author Administrator
*
*/
@RequestMapping("/Student")
@Controller
public class Controller { @Autowired
PageService service; /**
*
* @param query
* @return
*/
@ResponseBody
@RequestMapping("all")
public JSONObject selectAll(StudentQuery query) {
JSONObject jsonObject = new JSONObject();
jsonObject.put("student", service.findByQuery(query));
return jsonObject;
}
}
分页简单的封装SSM+easyUi的更多相关文章
- 对bootstrap modal的简单扩展封装
对bootstrap modal的简单扩展封装 参考自:http://www.muzilei.com/archives/677 注:原文不支持bootstrap新版本,并且居中等存在问题 此段时间 ...
- android中RecycleView分页原生代码封装,无任何第三方代
概述 RecycleView分页加载封装,简单方便,功能齐全 详细 代码下载:http://www.demodashi.com/demo/13283.html 一.场景: 在项目开发中经常使用到列表集 ...
- [分享] 史上最简单的封装教程,五分钟学会封装系统(以封装Windows 7为例)
[分享] 史上最简单的封装教程,五分钟学会封装系统(以封装Windows 7为例) 踏雁寻花 发表于 2015-8-23 23:31:28 https://www.itsk.com/thread-35 ...
- 一个用python简单的封装了aria2的jsonrpc中adduri的脚本
aria2是一个十分牛逼的下载神器,有时候项目需要一个很牛逼的下载中间件的话,aria2是一个不错的选择.其中支持jsonrpc和websocket的特性尤其诱人.但是python用起来还是有点不爽, ...
- Django分页类的封装
Django分页类的封装 Django ORM 封装 之前有提到(Django分页的实现)会多次用到分页,将分页功能封装起来能极大提高效率. 其实不是很难,就是将之前实现的代码全都放到类中,将需要用 ...
- 最新 AFNetworking 3.0 简单实用封装
AFNetworking 3.0 的到来使我们开发者又方便了许多,话不多说,直接上代码. 1.首先 引入框架AFNetworking框架 GitHub下载地址:https://github.com/A ...
- React+Echarts简单的封装套路
今天我们来介绍一下React中,对Echarts的一个简单的封装. 首先在我们的React项目中,想使用Echart包,首先需要先安装它,安装代码如下,任选一个就可以 cnpm install ech ...
- easyUI中treegrid组件构造树形表格(简单数据类型)+ssm后台
这几天做的项目要求用树形表格的形式展示一部分数据,于是就想到了使用easyUI的treegrid组件,但几经翻查各种资料,发现数据类型大多采取标准数据类型,即包含children元素的数据类型,小编查 ...
- 作为新手在学习SSM+Easyui过程中遇到一系列问题
对于初学SSM来说,如果不熟悉SSM中SpringMVC对数据处理,会造成很大的困扰, SSM中对前台页面放在WEB-INF下,对于读取外部信息,例如导入easyui的js文件.以及不能直接进行跳转. ...
随机推荐
- 软件工程工具学习(1)---Visio
要给15级软件工程上机了.开个系列记录软件工程开发过程中所会用到的一些工具的学习. 第一篇---软件分析与设计工具 Microsoft Visio Visio 介绍 1.Visio是一款矢量图形与图标 ...
- mongo数据库基础
mongodb mongodb特性 分布式文件存储 介与关系数据库和非关系数据库之间 文件存储格式为BSON(一种JSON的扩展) BSON是对二进制格式的JSON的简称,BSON支持文档和数组的嵌套 ...
- oh-my-zsh 安装和使用
oh-my-zsh是github用户robbyrussell的一款为简化zsh配置而开发的开源项目. 其github地址:https://github.com/robbyrussell/oh-my-z ...
- 篇3 安卓app自动化测试-搞定界面元素
篇3 安卓app自动化测试-搞定界面元素 --lamecho辣么丑 1.1概要 大家好! 我是lamecho(辣么丑),今天是<安卓app自动化测试>的第三 ...
- 最新的css3动画按钮效果
效果演示 插件下载
- vue视频学习笔记07
video 7 vue问题:论坛http://bbs.zhinengshe.com------------------------------------------------UI组件别人提供好一堆 ...
- 模仿下拉框datalist的jquery插件的一点小经验
原本项目里是用h5的新属性data-list,但是这个下拉框的数据太多,而data-list似乎没有设置高度的地方,所以写了个小插件,期间也发现了一些bug,目前这个版本算是可以一用的版本,故写一下这 ...
- java之 Timer 类的使用以及深入理解
最近一直在看线程知识,然后看到Timer定时器使用了线程实现的定时功能,于是了解了解: 本文 从Time类的使用和源码分析两个方面讲解: 1---Timer类使用 2---源码分析 1.Time类使用 ...
- 远程登录Linux服务器修改ssh端口
公司有部分服务器root密码被禁用,有部分没有禁用,禁用root的服务器需要通过tomcat用户登陆系统,切换至root修改端口,没有禁用的直接修改root密码: #-*- coding:utf-8 ...
- MSSQL-Scripter,一个新的生成T-SQL脚本的SQL Server命令行工具
这里向大家介绍一个新的生成T-SQL脚本的SQL Server命令行工具:mssql-scripter.它支持在SQL Server.Azure SQL DB以及Azure SQL DW中为数据库生成 ...