mybatis的分页和特殊字符处理

简介: mybatis的分页和特殊字符处理

1. 什么是分页

分页是指将大量数据按照固定大小进行划分,每次只查询一部分数据并进行展示。在数据库查询中,分页可以提高查询效率和用户体验。

1.2. MyBatis中的分页实现方式

MyBatis提供了多种实现分页的方式,其中常用的有两种:

1.2.1. 基于参数的分页

通过在Mapper接口的方法中加入相关参数来实现分页功能。常见的参数包括offset(偏移量)和limit(每页数据量)。使用这种方式,开发者需要手动计算参数,然后在SQL语句中使用LIMIT关键字来限制查询结果的数量。

示例代码:

java @Select(“SELECT * FROM users LIMIT #{offset}, #{limit}”)

List getUsers(@Param(“offset”) int offset, @Param(“limit”) int

limit);

1.2.2. 使用插件实现分页

MyBatis还支持使用插件来实现分页功能。插件可以自定义拦截器,在执行SQL前后进行一些额外的处理,比如修改查询语句、计算总记录数等。常见的分页插件有PageHelper、PaginationInterceptor等。

使用插件实现分页的好处是可以减少开发工作量,不需要手动编写分页逻辑,并且可以提供更加灵活的分页功能。

bookmapper.xml

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

bookMapper

List<Book> queryByMinMax(BookDto bookDto);

bizimpl

public List<Book> BookListPager(String bname, PageBean pageBean) {
        if (pageBean!=null&& pageBean.isPagination()){
            PageHelper.startPage(pageBean.getPage(),pageBean.getRows());
        }
       List<Book>books= bookMapper.BookListPager(bname);
        if(pageBean!=null && pageBean.isPagination()){
            PageInfo<Book> pageInfo = new PageInfo<>(books);
            pageBean.setTotal((int) pageInfo.getTotal());
        }
        return books;
    }

demo

public void text5(){
        PageBean pageBean = new PageBean();
        pageBean.setPage(1);
        pageBean.setRows(20);
        bookBiz.BookListPager("圣墟", pageBean).forEach(System.out::println);
    }

1.3. 避免SQL注入的技巧

SQL注入是一种常见的安全漏洞,攻击者通过在用户输入的数据中插入恶意SQL语句,从而执行非法的数据库操作。为了防止SQL注入,我们可以采取以下技巧:

1.3.1. 使用预编译语句

预编译语句是指在执行SQL语句之前,将SQL语句发送给数据库进行编译,然后再传入参数执行。这样可以避免直接拼接参数值到SQL语句中,从而减少了注入的可能性。

1.3.2. 参数化查询

参数化查询是将SQL语句中需要动态传入的参数使用占位符来表示,然后将参数值与SQL语句分开传递给数据库执行。这样可以确保参数值被正确地转义和处理,避免了SQL注入的风险。

示例代码:

java

@Select(“SELECT * FROM users WHERE username = #{username}”)

User getUserByUsername(@Param(“username”) String username);

二、特殊字符的正确使用方式

2.1. 什么是特殊字符

特殊字符是指在SQL语句中具有特殊含义的字符,比如’、"、%等。如果不正确处理这些特殊字符,可能会导致SQL语句解析错误或者产生安全隐患。

2.2. 特殊字符在SQL查询中的作用

特殊字符在SQL查询中有不同的作用,比如’用于表示字符串的起始和结束,%用于模糊匹配等。如果在输入的数据中包含这些特殊字符,并且没有正确处理,可能会导致查询结果不准确或者产生意外的结果。

2.3. 如何避免特殊字符引起的问题

为了避免特殊字符引起的问题,我们可以采取以下两种方式:

2.3.1. 使用CDATA区段

在编写SQL语句时,可以使用CDATA区段来将SQL语句包裹起来,这样特殊字符就不会被解析为XML的保留字符。示例代码:

<select id="queryByMinMax" resultType="com.niyin.model.Book" parameterType="java.util.Map">
  select
  <include refid="Base_Column_List" />
  from t_mvc_book
  where price &gt;#{min} and price &lt; #{max}
--   where <![CDATA[
--   price <#{max} and price > #{min}
  ]]>
  </select>

. 使用实体引用

在输入数据中包含特殊字符时,可以将这些特殊字符使用实体引用来代替。比如将<替换为<,将>替换为>等。这样可以确保特殊字符被正确地解析和处理。

示例代码:

<select id="queryByMinMax" resultType="com.niyin.model.Book" parameterType="java.util.Map">
  select
  <include refid="Base_Column_List" />
  from t_mvc_book
  where price &gt;#{min} and price &lt; #{max}
--   where <![CDATA[
--   price <#{max} and price > #{min}
  ]]>
  </select>

三、总结和展望

3.1. MyBatis的优点和不足

优点

简化了数据库操作,通过配置文件和注解可以快速实现数据访问层的开发。

提供了灵活的SQL编写方式,支持动态SQL、参数映射等功能。

可以与各种主流数据库进行集成。

不足之处

对于复杂的查询需求,需要编写较多的SQL语句,增加了开发工作量。

需要手动管理数据库连接,没有像Hibernate那样的ORM框架自动管理事务。

3.2. 未来发展趋势和应用场景

随着大数据和云计算的快速发展,数据处理的需求越来越复杂。MyBatis作为一种轻量级的ORM框架,具有简单、灵活和可定制化的特点,在各种应用场景中仍然具有广泛的使用价值。

未来的发展趋势可能包括:

进一步优化性能,提高查询效率。

支持更多的数据库类型和技术栈。

提供更多的插件和工具,方便开发者使用和扩展。

对于需要对数据库进行精细控制和自定义操作的项目,MyBatis仍然是一个不错的选择;对于对ORM框架要求较高的项目,可能会选择其他更加全面的框架如Hibernate等。

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