mybatis之模糊查询方法

6 篇文章 1 订阅

mybatis之模糊查询方法

方法一: 使用CONCAT(like concat)

like concat (参数一,参数二,参数三):用于模糊查询,不推荐直接用like,所以用concat连接
1.参数一: 第一个基本上用 ‘%’
2.参数二: 传入的参数
3.参数三: 第三个基本上用 ‘%’(和第一个对应)

 <if test="blockPushLog.blockName!=null and blockPushLog.blockName!=''">
     and b.BLOCK_NAME like CONCAT('%',#{blockPushLog.blockName},'%')
 </if>

方法二: 使用bind模糊查询(推荐优先使用)

bind(参数一,参数二):用于模糊查询

  1. 参数一: name:自定义名称,变量名,用于赋予like后面的名称
  2. 参数二: value: 传入的参数
 <if test="blockPushLog.blockSearch!=null and blockPushLog.blockSearch!=''">
      <bind name="blockNameLike" value="'%'+blockPushLog.blockSearch+'%'"/>
       and b.BLOCK_NAME like #{blockNameLike}
 </if>

两者区别

  1. like concat :
    (1).使用concat函数连接字符串,在mysql中这个函数支持多个参数,但是其他数据库不一定支持多个参数,因而兼容性弱;
    (2)因为直接使用:(’%’+参数+ ‘%’),存在sql注入的情况下,也可以把你写的sql语句看成不同的部分分割来对待,即安全性差,容易遭到攻击
  2. bind:(推荐优先使用)
    (1) 各数据库通用,兼容性强
    (2) 可以预防SQL注入(比like concat强),因而安全性也强
  • 7
    点赞
  • 63
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱丫爱

你的鼓励是我创作最大的动力来源

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值