MyBatis分页插件PageHelper的使用及MyBatis的特殊符号---详细介绍

简介: MyBatis分页插件PageHelper的使用及MyBatis的特殊符号---详细介绍

一,分页的概念

分页是一种将大量数据或内容分割成多个页面以便逐页显示的方式。在分页中,数据被分割成一定数量的页,每页显示一部分数据或内容,用户可以通过翻页或跳分页是一种将大量数据或内容分割成多个页面以便逐页显示的方式。在分页中,数据被分割成一定数量的页,每页显示一部分数据或内容,用户可以通过翻页或跳转页面来浏览更多内容。转页面来浏览更多内容

1.1 分页应用场景

数据展示:

    当需要展示大量数据,并将其划分为多个页面进行逐页查看时,可以使用分页应用。例如,在电子商务网站上展示商品列表或搜索结果时,分页应用可以提供良好的用户体验

数据浏览:

    当需要在一个长列表或长文档中进行浏览时,分页应用可以将内容分割成多个页面,方便用户逐页阅读或浏览。例如,在新闻网站上浏览新闻文章或在书籍电子阅读器中阅读电子书时,分页应用可以让用户更加方便地跳转页面

搜索结果分页:

    当进行搜索操作时,检索出来的结果可能非常庞大,分页应用可以将搜索结果分页展示,以便用户逐页查看结果。这在搜索引擎、论坛或社交媒体平台等场景下非常常见

1.2 分页的优点

提高性能:

   分页应用可以将大量数据分割成多个页面,只加载当前页面所需的数据,从而减轻数据库和服务器的负载,提高查询和渲染速度。

改善用户体验:

  通过分页,用户可以更方便地浏览和导航大量数据,减少页面滚动和加载时间,提高交互效率和用户满意度。

灵活导航:

   分页应用可以为用户提供灵活的导航选项,允许用户跳转到特定页面,或者调整每页显示的数据量,以满足个性化需求。

数据安全性:

   通过限制每页数据的数量,分页应用可以限制对数据的访问,提高数据的安全性和隐私保护。

二,分页功能的实现

本文章根据上篇文章内容进行扩展实现分页功能,上一篇连接地址:简单的模糊查询

为了让分页更加提高效率我们用的是一个PageHelper插件,让插件来来帮助我们实现这个功能

pom.xml导入PageHelper插件

<!-- **********************  分页 Pom依赖 ********************** -->
    <dependency>
      <groupId>com.github.pagehelper</groupId>
      <artifactId>pagehelper</artifactId>
      <version>5.1.2</version>
    </dependency>

mybatis.xml配置拦截器

注意:该配置受dtd约束影响,要注意配置的位置,不然根目录会报错

<plugins>
        <!-- 配置分页插件PageHelper, 4.0.0以后的版本支持自动识别使用的数据库 -->
        <plugin interceptor="com.github.pagehelper.PageInterceptor">
        </plugin>
    </plugins>

Mapper.xml的配置:

<select id="mhcx4" resultType="com.Bing.model.Book" parameterType="java.util.Map" >
    select
    <include refid="Base_Column_List" />
    from t_mvc_book
    where bname like concat('%',#{bname},'%')
  </select>

在uils导入PageBean工具类

package com.Bing.util;
import javax.servlet.http.HttpServletRequest;
import java.io.Serializable;
import java.util.Map;
public class PageBean implements Serializable {
  private static final long serialVersionUID = 2422581023658455731L;
  //页码
  private int page=1;
  //每页显示记录数
  private int rows=10;
  //总记录数
  private int total=0;
  //是否分页
  private boolean isPagination=true;
  //上一次的请求路径
  private String url;
  //获取所有的请求参数
  private Map<String,String[]> map;
  public PageBean() {
    super();
  }
  //设置请求参数
  public void setRequest(HttpServletRequest req) {
    String page=req.getParameter("page");
    String rows=req.getParameter("rows");
    String pagination=req.getParameter("pagination");
    this.setPage(page);
    this.setRows(rows);
    this.setPagination(pagination);
    this.url=req.getContextPath()+req.getServletPath();
    this.map=req.getParameterMap();
  }
  public String getUrl() {
    return url;
  }
  public void setUrl(String url) {
    this.url = url;
  }
  public Map<String, String[]> getMap() {
    return map;
  }
  public void setMap(Map<String, String[]> map) {
    this.map = map;
  }
  public int getPage() {
    return page;
  }
  public void setPage(int page) {
    this.page = page;
  }
  public void setPage(String page) {
    if(null!=page&&!"".equals(page.trim()))
      this.page = Integer.parseInt(page);
  }
  public int getRows() {
    return rows;
  }
  public void setRows(int rows) {
    this.rows = rows;
  }
  public void setRows(String rows) {
    if(null!=rows&&!"".equals(rows.trim()))
      this.rows = Integer.parseInt(rows);
  }
  public int getTotal() {
    return total;
  }
  public void setTotal(int total) {
    this.total = total;
  }
  public void setTotal(String total) {
    this.total = Integer.parseInt(total);
  }
  public boolean isPagination() {
    return isPagination;
  }
  public void setPagination(boolean isPagination) {
    this.isPagination = isPagination;
  }
  public void setPagination(String isPagination) {
    if(null!=isPagination&&!"".equals(isPagination.trim()))
      this.isPagination = Boolean.parseBoolean(isPagination);
  }
  /**
   * 获取分页起始标记位置
   * @return
   */
  public int getStartIndex() {
    //(当前页码-1)*显示记录数
    return (this.getPage()-1)*this.rows;
  }
  /**
   * 末页
   * @return
   */
  public int getMaxPage() {
    int totalpage=this.total/this.rows;
    if(this.total%this.rows!=0)
      totalpage++;
    return totalpage;
  }
  /**
   * 下一页
   * @return
   */
  public int getNextPage() {
    int nextPage=this.page+1;
    if(this.page>=this.getMaxPage())
      nextPage=this.getMaxPage();
    return nextPage;
  }
  /**
   * 上一页
   * @return
   */
  public int getPreivousPage() {
    int previousPage=this.page-1;
    if(previousPage<1)
      previousPage=1;
    return previousPage;
  }
  @Override
  public String toString() {
    return "PageBean [page=" + page + ", rows=" + rows + ", total=" + total + ", isPagination=" + isPagination
        + "]";
  }
}

Mapper类方法:

List<Book> mhcx4(@Param("bname") String bname);

在Mapper.xml配置的方法名进行定义相对应的接口和实现类

接口方法:

List<Book> mhcx4(String bname, PageBean pageBean);

实现类:

@Override
    public List<Book> mhcx4(String bname, PageBean pageBean) {
         if(pageBean!=null && pageBean.isPagination()){
             PageHelper.startPage(pageBean.getPage(),pageBean.getRows());
         }
         List<Book> books=bookMapper.mhcx4("圣墟");
         if(pageBean!=null && pageBean.isPagination()){
             PageInfo<Book> info = new PageInfo<Book>(books);
             System.out.println("当前页:"+ info.getPageNum());
             System.out.println("展示记录数:"+info.getPageSize());
             System.out.println("符合查询条件的总记录:"+info.getTotal());
             pageBean.setTotal((int) info.getTotal());
         }
        return books;
    }

测试:

@Test
    public void mhcx4() {
        PageBean pageBean=new PageBean();//实例化PageBean
        pageBean.setPage(2);//第几页
        pageBean.setRows(15);//显示的条目
        bookBiz.mhcx4("圣墟",pageBean).forEach(System.out::println);//模糊查询
    }

运行结果:

如果不想用分页功能单纯的想展示所有数据的话,在测试的时候调用下面方法即可

pageBean.setPagination(false);

三,Mybatis特殊字符

MyBatis 中,有几个特殊字符需要进行转义或处理,以避免 SQL 解析错误或相关问题。以下是一些常见的特殊字符及其处理方式

< 和 >

    这两个字符在 XML 文件中有特殊含义,因此需要进行转义。可以使用 &lt;&gt; 分别表示 <>

&

    也需要进行转义,可以使用 &amp; 表示

'

   当在 SQL 查询语句中使用字符串参数时,需要注意单引号的处理。可以使用双引号包裹字符串,或者使用两个单引号来转义一个单引号。例如:SELECT * FROM user WHERE name = "John"SELECT * FROM user WHERE name = 'O''Connor'

%_

    在使用 LIKE 语句进行模糊查询时,% 表示任意数量的字符,而 _ 表示一个字符。如果需要在字符串中使用字面量 %_,则需要使用 \ 进行转义。例如:SELECT * FROM user WHERE name LIKE '%\%%' ESCAPE '\'

|&

   在使用动态 SQL 标签(如 <if><choose><foreach> 等)时,| 表示逻辑 OR 运算符,而& 表示逻辑 AND 运算符。如果要显示字面量的 |& ,则需要使用 \ 进行转义。例如:<![CDATA[${param1} \| ${param2}]]>

目录
相关文章
|
1月前
|
SQL Java 数据库连接
MyBatis分页
MyBatis作为Java持久层框架,需结合数据库特性或插件实现分页。分页分为物理分页(如MySQL的LIMIT)和逻辑分页(内存截取),推荐使用PageHelper插件自动注入分页语句,提升开发效率与性能。需注意索引优化、深分页问题及多表关联时的兼容性,结合业务场景选择合适方案。
98 4
|
7月前
|
SQL Java 数据库连接
微服务——MyBatis分页
本文介绍了分页的多种实现方式,包括自带RowBounds分页、第三方插件PageHelper分页、SQL分页、数组分页及拦截器分页。其中,RowBounds是先查询全部结果再内存分页;PageHelper通过修改SQL动态添加分页关键字;SQL分页依赖数据库自身的分页功能如`LIMIT`;数组分页则是查询全量数据后用`subList`方法截取;拦截器分页则统一在SQL后添加分页语句。最后总结逻辑分页适合小数据量,但大数据量易内存溢出;物理分页虽小数据量效率较低,但更适合大数据场景,优先推荐使用。
97 0
|
7月前
|
SQL Oracle 关系型数据库
【YashanDB知识库】Mybatis-Plus调用YashanDB怎么设置分页
【YashanDB知识库】Mybatis-Plus调用YashanDB怎么设置分页
|
4月前
|
Java 数据库连接 数据库
Spring boot 使用mybatis generator 自动生成代码插件
本文介绍了在Spring Boot项目中使用MyBatis Generator插件自动生成代码的详细步骤。首先创建一个新的Spring Boot项目,接着引入MyBatis Generator插件并配置`pom.xml`文件。然后删除默认的`application.properties`文件,创建`application.yml`进行相关配置,如设置Mapper路径和实体类包名。重点在于配置`generatorConfig.xml`文件,包括数据库驱动、连接信息、生成模型、映射文件及DAO的包名和位置。最后通过IDE配置运行插件生成代码,并在主类添加`@MapperScan`注解完成整合
729 1
Spring boot 使用mybatis generator 自动生成代码插件
|
5月前
|
SQL Java 数据安全/隐私保护
发现问题:Mybatis-plus的分页总数为0,分页功能失效,以及多租户插件的使用。
总的来说,使用 Mybatis-plus 确实可以极大地方便我们的开发,但也需要我们理解其工作原理,掌握如何合适地使用各种插件。分页插件和多租户插件是其中典型,它们的运用可以让我们的代码更为简洁、高效,理解和掌握好它们的用法对我们的开发过程有着极其重要的意义。
566 15
|
7月前
|
SQL Java 关系型数据库
MyBatis篇-分页
本文介绍了多种分页方式,包括自带rowbound内存分页、第三方插件pagehelper(通过修改SQL实现分页)、SQL分页(依赖limit或rownum等关键字)、数组分页(先查询全部数据再用subList分页)、拦截器分页(自定义拦截器为SQL添加分页语句)。最后总结了逻辑分页(内存分页,适合小数据量)和物理分页(直接在数据库层面分页,适合大数据量)的优缺点,强调物理分页优先于逻辑分页。
|
7月前
|
SQL Java 数据库连接
MyBatis 实现分页的机制
MyBatis 的分页机制主要依赖于 `RowBounds` 对象和分页插件。`RowBounds` 实现内存分页,适合小数据量场景,通过设定偏移量和限制条数对结果集进行筛选。而针对大数据量,则推荐使用分页插件(如 PageHelper),实现物理分页。插件通过拦截 SQL 执行,动态修改语句添加分页逻辑,支持多种数据库方言。配置插件后,无需手动调整查询方法即可完成分页操作,提升性能与灵活性。
155 0
|
7月前
|
XML Java 数据库连接
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——基于注解的整合
本文介绍了Spring Boot集成MyBatis的两种方式:基于XML和注解的形式。重点讲解了注解方式,包括@Select、@Insert、@Update、@Delete等常用注解的使用方法,以及多参数时@Param注解的应用。同时,针对字段映射不一致的问题,提供了@Results和@ResultMap的解决方案。文章还提到实际项目中常结合XML与注解的优点,灵活使用两者以提高开发效率,并附带课程源码供下载学习。
599 0
|
9月前
|
前端开发 Java 数据库连接
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
356 2
|
Java 数据库连接 Maven
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和MyBatis Generator,使用逆向工程来自动生成Java代码,包括实体类、Mapper文件和Example文件,以提高开发效率。
515 2
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。