您当前的位置: 首页 > 数据库教程 > MySQL教程 > mysql用like模糊查询的转义字符问题

mysql用like模糊查询的转义字符问题

作者:不详 来源:网络 发布时间: 2011-09-30 11:34 点击:
mysql用like模糊查询的转义字符问题 在mysql中对\n,\0,\',\,\b,\r,\t,\Z,\这些特殊字符进行查找的时候,如果用=这些进行精确匹配的时候条件值为 \\n,\\0,\\',\\,\\b,\\r,\\t,\\Z,\\就可以进行准确查找; 但是如果使用like的话就应是使用:\\\\n,\\\\0,\\\\',\\\\,\\\\b,

mysql用like模糊查询的转义字符问题

mysql用like模糊查询的转义字符问题

在mysql中对\n,\0,\',\",\b,\r,\t,\Z,\这些特殊字符进行查找的时候,如果用=这些进行精确匹配的时候条件值为
\\n,\\0,\\',\\",\\b,\\r,\\t,\\Z,\\就可以进行准确查找;

但是如果使用like的话就应是使用:\\\\n,\\\\0,\\\\',\\\\",\\\\b,\\\\r,\\\\t,\\\\Z,\\\\。

由于 MySQL在字符串中使用 C转义语法(例如, 用'\n'代表一个换行字符),在LIKE字符串中,必须将用到的'\'双写。例如, 若要查找'\n',
必须将其写成 ‘\\n’。

而若要查找 '\', 则必须将其写成 it as '\\\\';原因是反斜线符号会被语法分析程序剥离一次,在进行模式匹配时,又会被剥离一次,最后
会剩下一个反斜线符号接受匹配。

以下是我测试的结果:
SELECT 'aa''a""a' ; --> aa'a""a
SSELECT '\\\\n' ; --> \\n
SELECT '\\n' ; --> \n
SELECT '\\n' like '\\n' ; --> 0
SELECT '\\n' like '%\\n' ; --> 1
SELECT '\\n' like '_\\n' ; --> 1

分享到:
本文"mysql用like模糊查询的转义字符问题"由远航站长收集整理而来,仅供大家学习与参考使用。更多网站制作教程尽在远航站长站。
顶一下
(0)
0%
踩一下
(0)
0%
[点击 次] [返回上一页] [打印]
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 密码: 验证码:
关于本站 - 联系我们 - 网站声明 - 友情连接- 网站地图 - 站点地图 - 返回顶部
Copyright © 2007-2013 www.yhzhan.com(远航站长). All Rights Reserved .
远航站长:为中小站长提供最佳的学习与交流平台,提供网页制作与网站编程等各类网站制作教程.
官方QQ:445490277 网站群:26680406 网站备案号:豫ICP备07500620号-4