Mysql 模糊匹配和转义字符
2016-01-18 11:33
561 查看
首先创建一个测试表:
现在我想使用模糊匹配,查出以 “\\172” 开头的字符串。
需要使用like 因为"\"是转义字符,所以需要使用4个"\".语句如下:
结果无法得到我想要的数据,按理说这个字符串经过转义后变成“\\172%”应该得到结果才对。
经过多次不同的尝试,最终成功的语句如下:
分析原因可能如下:
在mysql解析这个语句时先进行了一次转义,将两个“\\"转义为一个“\"
条件变成: tt like '\\\\172%' 。然后在执行like语句时,又进行了一次转义,条件变成: tt like '\\172%'
这时才正确返回结果。
以上均为猜测,因为没有去好好研究mysql like 语句的行为。
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 使用SELECT ... FOR UPDATE 做事务写入前的确认(转)
- Mycat学习笔记 第三篇. MySql 主从同步异常后,主从切换
- 用sql脚本建立Mysql数据库及表
- mysql数据类型
- 【转】MYSQL主从同步故障一例及解决过程!
- mysql表复制
- 安装mysql 5.7 最完整版教程
- 延迟关联和覆盖索引
- MySQL中DATETIME、DATE和TIMESTAMP类型的区别
- mysql优化limit分页
- MYSQL特性
- MySQL 内置数学函数
- mysql 游标循环失效问题
- MySQL Online DDL
- mysql处理数据库中的部分数据
- MySql的join(连接)查询 (三表 left join 写法)
- MySQL:MySQL日期数据类型、MySQL时间类型使用总结
- NodeJs对Mysql封装
- Mysql存储过程
- MySQL中create table as 与like的区别分析