MySQL中关于查询条件中的字符串空格问题_MySQL
MySQL中关于查询条件中的字符串空格问题
假设当前mysql数据库中有个表:sysuser
有个字段是:sysUseName
字段中有条记录的内容是:robin
请看下面这两个SQL语句:
SELECT * from sysuser s where s.sysUseName = 'robin'
SELECT * from sysuser s where s.sysUseName = 'robin空格'
SELECT * from sysuser s where s.sysUseName = 'RoBin空格'
这三条语句均可以查询出那条记录。
官方文档上说是MySQL校对规则属于PADSPACE,对CHAR和VARCHAR值进行比较都忽略尾部空格,和服务器配置以及MySQL版本都没关系。
MySQL 安装目录下有个doc目录(Windows),里面的 Data Types -> String Types -> The CHAR and VARCHAR Types 这一小节有对这个问题的说明以及相关的例子(版本不一样可能章节的编号可能有变动,还是看标题吧): All MySQL collations are of type PADSPACE. This means that all CHAR and VARCHAR values in MySQL are compared without regard to any trailing spaces.
这样带来的问题是:我如何需要精确匹配robin这个内容?假设有一个登陆功能,我希望用户输入‘robin’可以登陆,但是输入‘robin空格’却不能登录,该如何实现。
解决办法如下:
SELECT * from sysuser s where s.sysUseName = BINARY 'robin '
BINARY不是函数,是类型转换运算符,它用来强制它后面的字符串为一个二进制字符串,可以理解为在字符串比较的时候区分大小写,精确匹配。
另外,因为有的MySQL特别是4.*以前的对于中文检索会有不准确的问题,可以在检索的时候加上binary。
bitsCN.com上一篇: PHP5函数小全(分享)_PHP
下一篇: php—Smarty-5 (22)
推荐阅读
-
MySQL中关于查询条件中的字符串空格问题_MySQL
-
7、使用WHERE子句查询表中满足条件的记录_MySQL
-
MySQL源码学习:关于慢查询日志中的Rows_examined=0
-
关于mysql中order by与group by的问题
-
关于之前mysql5.6.13中查询缓存疑问的解决方法_MySQL
-
请教个mysql问题.关于获取查询结果中某一个字段的最大值(按照其他字段排序)
-
MySQL中连接查询和子查询的问题
-
关于PHP中操作MySQL数据库的一些要注意的问题
-
python-关于mysql中的位图索引和位片索引问题
-
关于mysql api中my_bool的取值范围的问题_MySQL