• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

MyBatis Like 模糊查询有几种方式

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

方式1:$  这种方式,简单,但是无法防止SQL注入,所以不推荐使用

    LIKE  '%${name}%'

方式2:#

    LIKE "%"#{name}"%"

有兴趣的可以看一下:Mybatis 中#{} 和${}区别

方式3:字符串拼接

AND name LIKE CONCAT(CONCAT('%',#{name},'%'))

方式4:bind标签

  1. <select id="searchStudents" resultType="com.example.entity.StudentEntity"
  2. parameterType="com.example.entity.StudentEntity">
  3. <bind name="pattern1" value="'%' + _parameter.name + '%'" />
  4. <bind name="pattern2" value="'%' + _parameter.address + '%'" />
  5. SELECT * FROM test_student
  6. <where>
  7. <if test="age != null and age != '' and compare != null and compare != ''">
  8. age
  9. ${compare}
  10. #{age}
  11. </if>
  12. <if test="name != null and name != ''">
  13. AND name LIKE #{pattern1}
  14. </if>
  15. <if test="address != null and address != ''">
  16. AND address LIKE #{pattern2}
  17. </if>
  18. </where>
  19. ORDER BY id
  20. </select>

方式5:java代码里写

param.setUsername("%CD%"); 在 java 代码中传参的时候直接写上

           <if test="username!=null"> AND username LIKE #{username}</if>

然后 mapper 里面直接写 #{} 就可以了



鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
通常一个mapper.XML对应一个DAO接口,DAO是否可以重载?发布时间:2022-02-02
下一篇:
MyBatis动态sql语句(OGNL语法)发布时间:2022-02-02
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap