MyBatis 进行模糊查询

在使用 MyBatis 进行模糊查询时,为了防止 SQL 注入攻击,通常会使用预编译的 SQL。预编译的 SQL 可以通过 #{} 占位符来实现。以下是如何在 MyBatis 中使用预编译的 SQL 进行模糊查询的示例:

使用 XML 配置

假设你有一个 UserMapper.xml 文件,其中包含以下内容:

<mapper namespace="com.example.demo.mapper.UserMapper">

    <!-- 模糊查询用户 -->
    <select id="findUsersByKeyword" parameterType="string" resultType="com.example.demo.entity.User">
        SELECT * FROM user WHERE name LIKE CONCAT('%', #{keyword}, '%')
    </select>

</mapper>

在这个示例中,#{keyword} 是一个预编译的占位符,用于接收传入的参数。

使用注解配置

如果你更喜欢使用注解,可以在 Mapper 接口中使用 @Select 注解:

@Mapper
public interface UserMapper {

    @Select("SELECT * FROM user WHERE name LIKE CONCAT('%', #{keyword}, '%')")
    List<User> findUsersByKeyword(String keyword);

}

调用示例

无论你使用 XML 配置还是注解配置,调用方式都是相同的。假设你有一个 UserMapper 接口的实例 userMapper,你可以这样调用模糊查询方法:

String keyword = "John";
List<User> users = userMapper.findUsersByKeyword(keyword);

注意事项

  1. 防止 SQL 注入:使用 #{} 占位符可以有效防止 SQL 注入攻击。
  2. 字符串拼接:在 SQL 中使用 CONCAT 函数来拼接字符串,确保模糊查询的正确性。

通过这种方式,你可以在 MyBatis 中安全地进行模糊查询,并且避免 SQL 注入的风险。

  • 8
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值