spring-data-jpa 模糊查询特殊字符转义

当使用特殊字符 譬如 _ %等模糊查询时往往查询的结果不是我们想要的 _会匹配任意的一个字符 %会匹配任意多个字符。想要使用_ %进行模糊查询 必须对其进行转义

  例如下面的sql  

select * from orders where name like "%abc_%"

会匹配任意name包含 abc的数据 如果需要匹配 abc_则需要对下划线_转义

select * from orders where name like "%abc/_%" ESCAPE '/'

escpae '/'表示 对'/'后面的字符进行转义

多个特殊字符查询

select * from order where name like "%acb///_/%%" ESCAPE '/'

会匹配 包含acb/_%的数据。注意 escape 的字符/ 也必须要转义不然会被当作标识转义其后的字符

spring-data-jpa的写法

cb.like(root.get("name"),"%" +name.replaceAll("/","//").replaceAll("_","/_").replaceAll("%","/%")+"%",'/')

 

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值