当前位置: 首页 > news >正文

昆明建设厅培训网站文本网站代码空两格怎么做

昆明建设厅培训网站,文本网站代码空两格怎么做,中达世联网站建设,全网营销有哪些平台三 PageHelper 1 分页所需 // 原分页所需 1. 定义QueryObject类,传递分页参数,currentPage,pageSize,get start();方法 2. selectForCount()方法,总条数小于等于0说明不需要分页,大于0说明可以分页 3. se…

三 PageHelper

1 分页所需

// 原分页所需
1. 定义QueryObject类,传递分页参数,currentPage,pageSize,get start();方法
2. selectForCount()方法,总条数小于等于0说明不需要分页,大于0说明可以分页
3. selectForList()方法,查询当前页显示的结果集
4. 把数据封装到PageResult中计算上一页,下一页,总页数
5. 两个用户传的,两个数据库查的,三个需要计算的// 使用 PageHelper 后
1. 定义QueryObject2. selectForCount()方法,不写了
3. selectForList()方法,limit之后的内容不需要写了(各个数据库分页方法不同,PageHelper支持各个数据库,底层分页)
4. PageResult不写

2 PageHelper 介绍

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

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 包下的 ArgumentsMapTestArgumentsObjTest8. autoRuntimeDialect:默认值为 false。设置为 true 时,允许在运行时根据多数据源自动识别对应方言的分页 (不支持自动选择sqlserver2012,只能使用sqlserver),用法和注意事项参考下面的场景五。9. closeConn:默认值为 true。当使用运行时动态数据源或没有设置 helperDialect 属性自动获取数据库类型时,会自动获取一个数据库连接, 通过该属性来设置是否关闭获取的这个连接,默认true关闭,设置为 false 后,不会关闭获取的连接,这个参数的设置要根据自己选择的数据源来决定。

3 导入依赖

<dependency><groupId>com.github.pagehelper</groupId><artifactId>pagehelper-spring-boot-starter</artifactId><version>1.3.0</version>
</dependency>

4 application.properties 配置文件 – 小改

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

5 PageInfo对象属性

// 总条数和每页显示的数据在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

// controller层@Autowiredprivate IDepartmentService departmentService;// 处理部门查询所有方法@RequestMapping("/list")public String list(Model model, QueryObject qo){PageInfo<Department> pageInfo = departmentService.query(qo);model.addAttribute("pageInfo",pageInfo);return "department/list";}
// service接口PageInfo<Department> query(QueryObject qo);
// service实现类@Overridepublic PageInfo<Department> query(QueryObject qo) {// 用的技术是线程变量(数据共享 controller service mapper都可以用(一条线程))// 告诉PageHelper当前页 每页显示条数后 PageHelper就会将这两个数据存入线程局部变量中// 传当前页 每页显示条数PageHelper.startPage(qo.getCurrentPage(),qo.getPageSize());return new PageInfo<>(departmentMapper.selectForList(qo));}
// mapper接口
List<Department> selectForList(QueryObject qo);
// xml 将limit删掉 此时线程变量中有当前页和每页总数 底层会自动计算出起始页
// service层调用了selectForList,pagehelper底层会自动截取select 后from 前的字段替换成count(0)进行计算总页数
// 再根据不同数据库的分页技术进行分页,而分页所需的数据都在线程中存在,所以limit不需要再写了
<select id="selectForList" resultMap="BaseResultMap">select id, name, snfrom department
</select>
// 前端调用
<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 样式的分页插件,用于前端绘制分页相关的样式效果。
分页

<!--导入引用-->
<script src="/static/js/plugins/twbsPagination/jquery.twbsPagination.min.js"></script>
<!--编写ul-->
<ul id="pagination-demo" class="pagination-sm"></ul>
<!--编写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();}});
http://www.yayakq.cn/news/109386/

相关文章:

  • 网站建设唐山大理住房和城乡建设局网站
  • 网站建设制度制定情况wordpress卡登录页面
  • 新手自己建设一个网站长沙营销型网站设计
  • php网站开发预算文档wordpress透明主题下载地址
  • flash怎么做电子书下载网站flash个人网站模板
  • 免费海外网站建设企业名录大全网
  • 郑州网站设手机网站模板带后台
  • 2022最新国际国内新闻wordpress seo theme
  • 沈阳网站建设沈阳wordpress显示注册ip
  • 全球网站制作asp.net网站入侵
  • 年前做网站的好处公司网站建设网络推广
  • 化妆品网站设计系统需求的策划书网站开发是哪个
  • 企业营销型网站建设规划做网站项目主要技术
  • 搞笑网站全站源码律师资格证报考条件
  • 长沙网站设计我选刻移动互联网开发期末考试
  • 北京南站到北京站坐地铁几号线电脑浏览器打不开是怎么回事
  • 申请建设工作网站的函买衣服网站排行榜前十名
  • 做网站推销的如何谈客户godaddy备份wordpress
  • 优秀网站开发公司婚庆设计图网站
  • 外贸定制网站建设电话广西seo关键词怎么优化
  • 网站建设后帐号密码石家庄net网站开发
  • 网站设计算什么费用装修公司怎么做免费网站
  • 网站建设制作公深圳商城手机网站建设
  • 怎样登录住房和城乡建设部网站安徽网站建设哪家有
  • 自己建设网站麻烦吗未来对网站建设的需求
  • 张槎网站制作宣传册排版
  • 做网站主机几个配件软件首页设计
  • 龙江网站设计制作达内网站开发课程
  • 济南做网站 推荐行知科技深圳市设计师服务平台
  • 企业中英文网站建设下页