Java研学-RBAC权限控制(二)

三 PageHelper

1 分页所需

java 复制代码
// 原分页所需
1. 定义QueryObject类,传递分页参数,currentPage,pageSize,get start();方法
2. selectForCount()方法,总条数小于等于0说明不需要分页,大于0说明可以分页
3. selectForList()方法,查询当前页显示的结果集
4. 把数据封装到PageResult中计算上一页,下一页,总页数
5. 两个用户传的,两个数据库查的,三个需要计算的

// 使用 PageHelper 后
1. 定义QueryObject类
2. selectForCount()方法,不写了
3. selectForList()方法,limit之后的内容不需要写了(各个数据库分页方法不同,PageHelper支持各个数据库,底层分页)
4. PageResult不写

2 PageHelper 介绍

PageHelper 是 MyBatis 的后端分页插件,将写好的 SQL 语句进行分页加工。无需自己去封装以及关心 SQL 分页等问题。默认情况下会使用 PageHelper 方式进行分页,如果想要实现自己的分页逻辑,可以实现 Dialect(com.github.pagehelper.Dialect) 接口,然后配置该属性为实现类的全限定名称,以下参数都是针对默认 dialect 情况下的参数。使用自定义 dialect 实现时,下面的参数没有任何作用。

java 复制代码
1. helperDialect:分页插件会自动检测当前的数据库链接,自动选择合适的分页方式。 你可以配置helperDialect属性来指定分页插件使用哪种方言。配置时,可以使用下面的缩写值:
oracle,mysql,mariadb,sqlite,hsqldb,postgresql,db2,sqlserver,informix,h2,sqlserver2012,derby也可以实现 AbstractHelperDialect,然后配置该属性为实现类的全限定名称即可使用自定义的实现方法。

2. offsetAsPageNum:默认值为 false,该参数对使用 RowBounds 作为分页参数时有效。 当该参数设置为 true 时,会将 RowBounds 中的 offset 参数当成 pageNum 使用,可以用页码和页面大小两个参数进行分页。

3. rowBoundsWithCount:默认值为false,该参数对使用 RowBounds 作为分页参数时有效。 当该参数设置为true时,使用 RowBounds 分页会进行 count 查询。

4. pageSizeZero:默认值为 false,当该参数设置为 true 时,如果 pageSize=0 或者 RowBounds.limit = 0 就会查询出全部的结果(相当于没有执行分页查询,但是返回结果仍然是 Page 类型)。

5. reasonable:分页合理化参数,默认值为false。当该参数设置为 true 时,pageNum<=0 时会查询第一页, pageNum>pages(超过总数时),会查询最后一页。默认false 时,直接根据参数进行查询。

6. params:为了支持startPage(Object params)方法,增加了该参数来配置参数映射,用于从对象中根据属性名取值, 可以配置 pageNum,pageSize,count,pageSizeZero,reasonable,不配置映射的用默认值, 默认值为pageNum=pageNum;pageSize=pageSize;count=countSql;reasonable=reasonable;pageSizeZero=pageSizeZero。

7. supportMethodsArguments:支持通过 Mapper 接口参数来传递分页参数,默认值false,分页插件会从查询方法的参数值中,自动根据上面 params 配置的字段中取值,查找到合适的值时就会自动分页。 使用方法可以参考测试代码中的 com.github.pagehelper.test.basic 包下的 ArgumentsMapTest 和 ArgumentsObjTest。

8. autoRuntimeDialect:默认值为 false。设置为 true 时,允许在运行时根据多数据源自动识别对应方言的分页 (不支持自动选择sqlserver2012,只能使用sqlserver),用法和注意事项参考下面的场景五。

9. closeConn:默认值为 true。当使用运行时动态数据源或没有设置 helperDialect 属性自动获取数据库类型时,会自动获取一个数据库连接, 通过该属性来设置是否关闭获取的这个连接,默认true关闭,设置为 false 后,不会关闭获取的连接,这个参数的设置要根据自己选择的数据源来决定。

3 导入依赖

java 复制代码
<dependency>
    <groupId>com.github.pagehelper</groupId>
    <artifactId>pagehelper-spring-boot-starter</artifactId>
    <version>1.3.0</version>
</dependency>

4 application.properties 配置文件 -- 小改

java 复制代码
// 分页插件
// 当前页总条数为0时查询所有,(相当于没有执行分页查询,但是返回结果仍然是 Page 类型)
pagehelper.page-size-zero=true
// 合理化配置 pageNum<=0 时会查询第一页, pageNum>pages(超过总数时),会查询最后一页
pagehelper.reasonable=true

5 PageInfo对象属性

java 复制代码
// 总条数和每页显示的数据在PageSerializable中
public class PageInfo<T> extends PageSerializable<T> {
    public static final int DEFAULT_NAVIGATE_PAGES = 8;
    //当前页
    private int pageNum;
    //每页的数量
    private int pageSize;
    //当前页的数量
    private int size;
    //由于startRow和endRow不常用,这里说个具体的用法
    //可以在页面中"显示startRow到endRow 共size条数据"
    //当前页面第一个元素在数据库中的行号
    private long startRow;
    //当前页面最后一个元素在数据库中的行号
    private long endRow;
    //总页数
    private int pages;
    //前一页
    private int prePage;
    //下一页
    private int nextPage;
    //是否为第一页
    private boolean isFirstPage = false;
    //是否为最后一页
    private boolean isLastPage = false;
    //是否有前一页
    private boolean hasPreviousPage = false;
    //是否有下一页
    private boolean hasNextPage = false;
    //导航页码数
    private int navigatePages;
    //所有导航页号
    private int[] navigatepageNums;
    //导航条上的第一页
    private int navigateFirstPage;
    //导航条上的最后一页
    private int navigateLastPage;
    
    ......
}

// 父方法
public class PageSerializable<T> implements Serializable {
    private static final long serialVersionUID = 1L;
    //总记录数
    protected long    total;
    //结果集
    protected List<T> list;
    ......
}

6 使用pagehelper

修改返回对象的类型,将原PageResult修改为Pagelnfo,可选中需修改的对象类型,通过ctrl+1组合键中的Make 'query 'return 'com.github.pagehelper.Pagelnfo<cn.tj.domain.Department>' 选项进行修改,同时对应的 query 方法的接口,实现类返回类型都会变成Pagelnfo

java 复制代码
// controller层
	@Autowired
    private IDepartmentService departmentService;
    // 处理部门查询所有方法
    @RequestMapping("/list")
    public String list(Model model, QueryObject qo){
        PageInfo<Department> pageInfo = departmentService.query(qo);
        model.addAttribute("pageInfo",pageInfo);
        return "department/list";
    }
java 复制代码
// service接口
	PageInfo<Department> query(QueryObject qo);
// service实现类
	@Override
    public PageInfo<Department> query(QueryObject qo) {
        // 用的技术是线程变量(数据共享 controller service mapper都可以用(一条线程))
        // 告诉PageHelper当前页 每页显示条数后 PageHelper就会将这两个数据存入线程局部变量中
        // 传当前页 每页显示条数
        PageHelper.startPage(qo.getCurrentPage(),qo.getPageSize());
        return new PageInfo<>(departmentMapper.selectForList(qo));
    }
java 复制代码
// mapper接口
List<Department> selectForList(QueryObject qo);
// xml 将limit删掉 此时线程变量中有当前页和每页总数 底层会自动计算出起始页
// service层调用了selectForList,pagehelper底层会自动截取select 后from 前的字段替换成count(0)进行计算总页数
// 再根据不同数据库的分页技术进行分页,而分页所需的数据都在线程中存在,所以limit不需要再写了
<select id="selectForList" resultMap="BaseResultMap">
        select id, name, sn
        from department
</select>
java 复制代码
// 前端调用
<table class="table table-hover table-bordered table-striped">
    <thead>
    <tr>
        <th>编号</th>
        <th>部门名称</th>
        <th>部门编号</th>
        <th>操作</th>
    </tr>
    </thead>
    <tbody>
    <tr th:each="department,start:${pageInfo.list}">
	    <td th:text="${start.count}">1</td>
        <td th:text="${department.name}">保安部</td>
        <td th:text="${department.sn}">BA</td>
        <td>
            <a href="#" class="btn btn-info btn-xs btn-input">
                <span class="glyphicon glyphicon-pencil"></span> 编辑
            </a>
            <a class="btn btn-danger btn-xs btn-delete">
                <span class="glyphicon glyphicon-trash"></span> 删除
            </a>
        </td>
    </tr>
    </tbody>
</table>

7 twbs-pagination 前端分页插件

twbs-pagination简单的自适应 Bootstrap 样式的分页插件,用于前端绘制分页相关的样式效果。

java 复制代码
<!--导入引用-->
<script src="/static/js/plugins/twbsPagination/jquery.twbsPagination.min.js"></script>
java 复制代码
<!--编写ul-->
<ul id="pagination-demo" class="pagination-sm"></ul>
java 复制代码
<!--编写jq 此时后台已经将总页数传递到前端了-->
$('#pagination-demo').twbsPagination({
		<!--总页数应通过Thymeleaf获取到后端传递的值-->
		<!--pages是PageInfo对象中的属性-->
        totalPages: [[${pageInfo.pages}]],
        
        <!--显示哪一个当前页 pageNum是PageInfo对象中的属性-->
        <!--startPage是前端插件中的属性 默认值为1-->
        startPage:[[${pageInfo.pageNum}]],
        
        first:'首页',
        prev:'上一页',
        next:'下一页',
        last:'尾页',
        
        <!--显示页数7-->
        visiblePages: 7,
        
        <!--当不知道传递的参数是何值时,可通过console.log(event),进行查看event是事件源对象,page是去第几页-->
        onPageClick: function (event, page) {
	        <!--更改表单currentPage的value值-->
            $('#currentPage').val(page);
            <!--更改当前页的值后提交对应表单-->
            $('#searchForm').submit();
        }
    });
相关推荐
漫漫进阶路2 小时前
VS C++ 配置OPENCV环境
开发语言·c++·opencv
陈平安Java and C2 小时前
MyBatisPlus
java
秋野酱2 小时前
如何在 Spring Boot 中实现自定义属性
java·数据库·spring boot
Bunny02123 小时前
SpringMVC笔记
java·redis·笔记
BinaryBardC3 小时前
Swift语言的网络编程
开发语言·后端·golang
feng_blog66883 小时前
【docker-1】快速入门docker
java·docker·eureka
code_shenbing4 小时前
基于 WPF 平台使用纯 C# 制作流体动画
开发语言·c#·wpf
邓熙榆4 小时前
Haskell语言的正则表达式
开发语言·后端·golang
ac-er88885 小时前
Yii框架中的队列:如何实现异步操作
android·开发语言·php
马船长5 小时前
青少年CTF练习平台 PHP的后门
开发语言·php