Spring Mybatis Mapper模糊查询的几种方法

 更新时间:2024年03月04日 11:55:15   作者:Mega Qi  
在Spring结合Mybatis进行开发时,实现模糊查询是一个常见需求,在Mybatis中,LIKE查询可以通过多种方式实现,本文给大家介绍了Spring Mybatis Mapper模糊查询的几种方法,需要的朋友可以参考下

在Spring结合Mybatis进行开发时,实现模糊查询是一个常见需求。在Mybatis中,LIKE查询可以通过多种方式实现,这取决于你的查询参数如何传递给Mybatis的SQL映射器。以下是实现模糊查询的几种常见方法:

1. 在Mapper接口中直接使用#{}进行拼接

这种方法直接在Mapper的XML文件中使用LIKE关键字,然后通过#{}传递参数,你可以在传递参数之前,在Java代码中拼接好模糊查询所需的百分比符号(%)。

Mapper接口XML示例:

<select id="findByName" resultType="com.example.YourModel">
  SELECT * FROM your_table
  WHERE name LIKE #{name}
</select>

Java代码中调用:

// 假设有一个Mapper接口方法叫findByName
List<YourModel> results = yourMapper.findByName("%" + name + "%");

2. 在XML中使用CONCAT函数

如果你不想在Java代码中拼接字符串,你可以在XML映射文件中使用SQL的CONCAT函数来拼接百分比符号和参数。

Mapper接口XML示例:

<select id="findByName" resultType="com.example.YourModel">
  SELECT * FROM your_table
  WHERE name LIKE CONCAT('%', #{name}, '%')
</select>

3. 使用<bind>标签

Mybatis提供了<bind>标签,允许你在XML文件中创建一个变量,用于拼接字符串或执行其他逻辑操作。这样可以在不修改Java代码的情况下实现字符串的拼接。

Mapper接口XML示例:

<select id="findByName" resultType="com.example.YourModel">
  <bind name="pattern" value="'%' + name + '%'" />
  SELECT * FROM your_table
  WHERE name LIKE #{pattern}
</select>

4. 使用${}进行拼接(不推荐)

虽然可以使用${}进行字符串拼接以实现LIKE查询,但这种方法容易导致SQL注入攻击,因此不推荐使用。

Mapper接口XML示例(不推荐):

<select id="findByName" resultType="com.example.YourModel">
  SELECT * FROM your_table
  WHERE name LIKE '%${name}%'
</select>

5. 使用MyBatis的动态SQL choose、when、otherwise

虽然不是专门用于LIKE查询,但choosewhenotherwise标签可以用于构建复杂的查询逻辑,包括根据条件选择是否执行模糊查询。

Mapper接口XML示例:

<select id="findByNameOrEmail" resultType="com.example.YourModel">
  SELECT * FROM your_table
  <where>
    <choose>
      <when test="name != null">
        name LIKE CONCAT('%', #{name}, '%')
      </when>
      <when test="email != null">
        email LIKE CONCAT('%', #{email}, '%')
      </when>
      <otherwise>
        1=1
      </otherwise>
    </choose>
  </where>
</select>

另外还有在调用层代码一些处理方式

6. 在Java代码中拼接模糊查询的条件

你也可以在调用Mapper接口的方法之前,就已经将参数值处理成模糊查询所需的格式。

public interface YourMapper {
    List<YourModel> findByName(@Param("name") String name);
}

// 调用Mapper的地方
String searchName = "%" + name + "%";
List<YourModel> result = yourMapper.findByName(searchName);

7. 使用@Select注解进行模糊查询

在使用Mybatis Spring时,可以直接在Mapper接口的方法上使用@Select注解来定义SQL语句,从而实现模糊查询。

public interface YourMapper {
    @Select("SELECT * FROM your_table WHERE name LIKE CONCAT('%', #{name}, '%')")
    List<YourModel> findByName(@Param("name") String name);
}

以上是实现Mybatis中LIKE模糊查询的一些常见方法。选择合适的方法取决于具体的应用场景和个人偏好。在实际使用中,要注意防止SQL注入的风险,尤其是在直接拼接字符串构造查询条件时。

到此这篇关于Spring Mybatis Mapper模糊查询的几种方法的文章就介绍到这了,更多相关Spring Mybatis Mapper模糊查询内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • SpringBoot如何对LocalDateTime进行格式化并解析

    SpringBoot如何对LocalDateTime进行格式化并解析

    这篇文章主要介绍了SpringBoot如何对LocalDateTime进行格式化方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-07-07
  • JAVA实现往字符串中某位置加入一个字符串

    JAVA实现往字符串中某位置加入一个字符串

    这篇文章主要介绍了JAVA实现往字符串中某位置加入一个字符串,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-08-08
  • Java设计模式中的适配器模式

    Java设计模式中的适配器模式

    这篇文章主要介绍了Java设计模式中的适配器模式, 适配器模式是将一个类的接口适配成用户所期待的,一个适配允许通常因为接口不兼容而不能在一起工作的类工作在一起,做法是将类自己的接口包裹在一个已存在的类中,需要的朋友可以参考下
    2024-01-01
  • springboot登陆页面图片验证码简单的web项目实现

    springboot登陆页面图片验证码简单的web项目实现

    这篇文章主要介绍了springboot登陆页面图片验证码简单的web项目实现,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-04-04
  • 浅谈Java中的atomic包实现原理及应用

    浅谈Java中的atomic包实现原理及应用

    这篇文章主要介绍了浅谈Java中的atomic包实现原理及应用,涉及Atomic在硬件上的支持,Atomic包简介及源码分析等相关内容,具有一定借鉴价值,需要的朋友可以参考下。
    2017-12-12
  • IDEA 当前在线人数和历史访问量的示例代码

    IDEA 当前在线人数和历史访问量的示例代码

    这篇文章主要介绍了IDEA 当前在线人数和历史访问量的实例代码,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-08-08
  • maven插件maven-jar-plugin构建jar文件的详细使用

    maven插件maven-jar-plugin构建jar文件的详细使用

    maven-jar-plugin插件时maven中最常用的插件,也是maven构建Java程序执行包或者依赖包的默认插件,本文主要介绍了maven插件maven-jar-plugin构建jar文件的详细使用,具有一定的参考价值,感兴趣的可以了解一下
    2024-02-02
  • 深入讲解Java 9中的九个新特性

    深入讲解Java 9中的九个新特性

    Java 8 发布三年多之后,即将快到2017年7月下一个版本发布的日期了。 你可能已经听说过 Java 9 的模块系统,但是这个新版本还有许多其它的更新。 这里有九个令人兴奋的新功能将与 Java 9 一起发布。需要的朋友可以参考学习,下面来一起看看吧。
    2017-05-05
  • Kotlin 基础语法实例详解

    Kotlin 基础语法实例详解

    这篇文章主要介绍了Kotlin 基础语法实例详解的相关资料,需要的朋友可以参考下
    2017-06-06
  • 详解MongoDB和Spring整合的实例代码

    详解MongoDB和Spring整合的实例代码

    这篇文章主要介绍了详解MongoDB和Spring整合的实例代码,Spring提供了MongoTemplate这样一个模板类的实现方法,简化了具体操作。有兴趣的可以了解一下
    2017-07-07

最新评论