首先创建一个测试表:
insert into test(tt) values('\\172.18.28.153');
现在我想使用模糊匹配,查出以 “\172” 开头的字符串。
需要使用like 因为""是转义字符,所以需要使用4个"".语句如下:
SELECT * from test where tt like '\\172%' ;
结果无法得到我想要的数据,按理说这个字符串经过转义后变成“\172%”应该得到结果才对。
经过多次不同的尝试,最终成功的语句如下:
SELECT * from test where tt like '\\\\172%' ;
分析原因可能如下:
在mysql解析这个语句时先进行了一次转义,将两个“\"转义为一个“"
条件变成: tt like '\\172%' 。然后在执行like语句时,又进行了一次转义,条件变成: tt like '\172%'
这时才正确返回结果。
以上均为猜测,因为没有去好好研究mysql like 语句的行为。