首页 > 数据库技术 > 详细

Mysql 模糊匹配和转义字符

时间:2016-01-18 12:11:07      阅读:335      评论:0      收藏:0      [点我收藏+]

首先创建一个测试表:

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 语句的行为。

 

Mysql 模糊匹配和转义字符

原文:http://www.cnblogs.com/champaign/p/5138721.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!