当使用特殊字符 譬如 _ %等模糊查询时往往查询的结果不是我们想要的 _会匹配任意的一个字符 %会匹配任意多个字符。想要使用_ %进行模糊查询 必须对其进行转义
例如下面的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("%","/%")+"%",'/')