Mybatis (3) ----- o uso de paginação

Índice

1. Consulta de paginação

Em segundo lugar, processamento de caracteres especiais

3. Resumo


Prefácio: Com base no sql dinâmico que aprendemos no artigo anterior, hoje continuaremos a explicar a paginação e o processamento de caracteres especiais do maybatis. Espero que este blog possa ajudá-lo!

1. Consulta de paginação

Por que reescrever a paginação do mybatis?

Existem vários motivos para substituir a funcionalidade de paginação do MyBatis.

Em primeiro lugar, a função de paginação padrão do MyBatis só pode realizar paginação simples, mas não pode atender a requisitos de paginação complexos . Ao reescrever a paginação do MyBatis, funções de paginação mais flexíveis e avançadas podem ser realizadas. Segundo, reescrever a paginação pode melhorar o desempenho do sistema.

Em segundo lugar, a implementação de paginação padrão do MyBatis é primeiro consultar todos os resultados ao consultar o banco de dados e, em seguida, filtrar os resultados de acordo com os parâmetros de paginação. Quando a quantidade de dados é grande, esse método levará a uma diminuição no desempenho da consulta e até mesmo a um problema de estouro de memória. Ao reescrever a paginação, você pode gerar SQL diretamente com instruções de paginação ao consultar o banco de dados, evitando carregamento desnecessário de dados e consumo de memória, melhorando assim o desempenho do sistema . Além disso, a reescrita da paginação também pode ser compatível com diferentes dialetos de banco de dados. Bancos de dados diferentes têm algumas diferenças na sintaxe de paginação. A implementação de paginação padrão do MyBatis só é aplicável a alguns bancos de dados e não pode ser compatível com todos os bancos de dados. Ao reescrever a paginação, as instruções de paginação correspondentes podem ser geradas de acordo com diferentes dialetos de banco de dados, de modo a realizar a função de paginação entre bancos de dados. Portanto, reescrever a função de paginação do MyBatis pode atender a requisitos de paginação mais complexos, melhorar o desempenho do sistema e ser compatível com diferentes dialetos de banco de dados.

Etapas para personalizar o uso de plug-ins de paginação:
1. Importar dependências pom

<dependency>
    <groupId>com.github.pagehelper</groupId>
    <artifactId>pagehelper</artifactId>
    <version>5.1.2</version>
</dependency>

Encontre o diretório de pasta correto, caso contrário o problema será grande.
2. Interceptador de configuração Mybatis.cfg.xml

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

3. Use PageHelper para paginação

package com.lya.util;
 
 
 
import javax.servlet.http.HttpServletRequest;
import java.io.Serializable;
import java.util.Map;
/**
 * @authorlya
 * @site www.lya.com
 * @create  2023-08-24 11:44
 */
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
                + "]";
    }
}

4. Lidar com resultados de paginação

①BookBiz

List<Map> listPager(Map map, PageBean pageBean);


②BookMapper.java

//    利用第三方插件进行分页
    List<Map> listPager(Map map);


③BookMapper.xml

<select id="listPager" resultType="java.util.Map" parameterType="java.util.Map">
  select * from t_mvc_book where bname like concat(concat('%',#{bname}),'%')
</select>


④BookBizImpl

@Override
    public List<Map> listPager(Map map, PageBean pageBean) {
//        pageHelper分页插件相关的代码
        if(pageBean!=null&&pageBean.isPagination()){
            PageHelper.startPage(pageBean.getPage(),pageBean.getRows());
        }
        List<Map> maps = bookMapper.listPager(map);
        if(pageBean!=null&&pageBean.isPagination()){
//            处理查询结果的前提是需要分页,是需要分页的
            PageInfo info = new PageInfo(maps);
            pageBean.setTotal(info.getTotal()+"");
        }
        return maps;
    }


⑤BookBizImplTest 

@Test
    public void listPager() {
        Map map=new HashMap();
        map.put("bname","圣墟");
//        bookBiz.listPager(map).forEach(System.out::println);
 
//        查询出第二页的20条数据
        PageBean pageBean = new PageBean();
        pageBean.setPage(2);
        pageBean.setRows(20);
 
        bookBiz.listPager(map,pageBean).forEach(System.out::println);

   

}

Em segundo lugar, processamento de caracteres especiais

2. Consulta difusa
 Quando escrevemos uma consulta difusa, geralmente escrevemos assim:

select * from t_mvc_book where bname like '%?%'

Em seguida, usamos o espaço reservado para passar o valor em segundo plano para consulta

Então será diferente depois de usar o Mybatis.Ele tem três maneiras de alterar a forma dessa consulta difusa:

  <select id="selectBooksLike1" resultType="com.zq.model.Book" parameterType="java.lang.String">
  select * from t_mvc_book where bname like #{bname}
</select>
  <select id="selectBooksLike2" resultType="com.zq.model.Book" parameterType="java.lang.String">
  select * from t_mvc_book where bname like '${bname}'
</select>
  <select id="selectBooksLike3" resultType="com.zq.model.Book" parameterType="java.lang.String">
  select * from t_mvc_book where bname like concat('%',#{bname},'%')
</select>


 Depois de escrever a configuração desses arquivos xml, também adicionaremos outras camadas de negócios

BookMapper.xml:
 


<select id="listPagerS" resultType="com.csdn.xw.model.Book" parameterType="java.util.Map">
  select * from t_mvc_book where bname like concat(concat('%',#{bname}),'%') and price < #{max}
</select>

BookBizImplTest 

 @Test
    public void listPagerS() {
        System.out.println("没有处理特殊字符之前");
        Map map=new HashMap();
        map.put("dname","圣墟");
        map.put("max",20);
        bookBiz.listPagerS(map).forEach(System.out::println);

 @Test
    public void listPagerS() {
        System.out.println("没有处理特殊字符之前");
        Map map=new HashMap();
        map.put("dname","圣墟");
        map.put("max",20);
        bookBiz.listPagerS(map).forEach(System.out::println);


 

3. Resumo

   Ao usarmos myBatis, encontraremos um problema ao fazer arquivos de configuração sql, ou seja, haverá conflitos entre caracteres especiais e colchetes de rótulo

Por exemplo: < e <

Qual é o significado? Ou seja, o primeiro é julgar que o símbolo é menor que, e o segundo é o parêntese esquerdo do rótulo, então como distingui-lo? Existem duas maneiras:

①: <![CDATA[ <= ]]> 

②:    <(<)  、     >(>)       &(&) 

por exemplo:

  ①BookBiz

 
  
  1. List<Book> list6(BookVo bookVo);

  2. List<Book> list7(BookVo bookVo);

②BookMapper.java

/**
     * 处理特殊字符
     * @param bookVo
     * @return
     */
    List<Book> list6(BookVo bookVo);
 
 
    /**
     * 处理特殊字符
     * @param bookVo
     * @return
     */
    List<Book> list7(BookVo bookVo);


③BookMapper.xml

<select id="list6" resultType="com.zq.model.Book" parameterType="com.zq.model.BookVo">
  select * from t_mvc_book
  <where>
    <if test="null != min and min != ''">
      <![CDATA[  and #{min} < price ]]>
    </if>
    <if test="null != max and max != ''">
      <![CDATA[ and #{max} >
  </where>
</select>
 
<select id="list7" resultType="com.javaxl.model.Book" parameterType="com.zq.model.BookVo"> price ]]>
    </if>
    select * from t_mvc_book
    <where>
      <if test="null != min and min != ''">
         and #{min} &lt; price
      </if>
      <if test="null != max and max != ''">
         and #{max} &gt; price
      </if>
    </where>
  </select>

④BookBizImpl

@Override
    public List<Book> list6(BookVo bookVo) {
        return bookMapper.list6(bookVo);
    }
 
    @Override
    public List<Book> list7(BookVo bookVo) {
        return bookMapper.list7(bookVo);
    }

⑤BookBizImplTest

 @Test
    public void list6() {
        BookVo vo=new BookVo();
        vo.setMax(45);
        vo.setMin(35);
        bookBiz.list6(vo).forEach(System.out::println);
    }
 
    @Test
    public void list7() {
        BookVo vo=new BookVo();
        vo.setMax(45);
        vo.setMin(35);
        bookBiz.list7(vo).forEach(System.out::println);
    }

Resultado dos testes:

Acho que você gosta

Origin blog.csdn.net/m0_73647713/article/details/132473635
Recomendado
Clasificación