前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Mock19-扩展知识点-Mybatis XML模糊查询的几种方法

Mock19-扩展知识点-Mybatis XML模糊查询的几种方法

作者头像
MegaQi
发布2024-03-25 12:14:21
780
发布2024-03-25 12:14:21
举报

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

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

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

Mapper接口XML示例:

代码语言:javascript
复制
<select id="findByName" resultType="com.example.YourModel">
  SELECT * FROM your_table
  WHERE name LIKE #{name}
</select>

Java代码中调用:

代码语言:javascript
复制
// 假设有一个Mapper接口方法叫findByName
List<YourModel> results = yourMapper.findByName("%" + name + "%");

2. 在XML中使用CONCAT函数

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

Mapper接口XML示例:

代码语言:javascript
复制
<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示例:

代码语言:javascript
复制
<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示例(不推荐):

代码语言:javascript
复制
<select id="findByName" resultType="com.example.YourModel">
  SELECT * FROM your_table
  WHERE name LIKE '%${name}%'
</select>

5. 使用MyBatis的动态SQL choosewhenotherwise

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

Mapper接口XML示例:

代码语言:javascript
复制
<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接口的方法之前,就已经将参数值处理成模糊查询所需的格式。

代码语言:javascript
复制
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语句,从而实现模糊查询。

代码语言:javascript
复制
public interface YourMapper {
    @Select("SELECT * FROM your_table WHERE name LIKE CONCAT('%', #{name}, '%')")
    List<YourModel> findByName(@Param("name") String name);
}

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

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2024-03-17,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 非典型性程序员 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 在Mapper接口中直接使用#{}进行拼接
  • 2. 在XML中使用CONCAT函数
  • 3. 使用<bind>标签
  • 4. 使用${}进行拼接(不推荐)
  • 5. 使用MyBatis的动态SQL choose、when、otherwise
  • 6. 在Java代码中拼接模糊查询的条件
  • 7. 使用@Select注解进行模糊查询
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档