假设当前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空格’却不能登录,该如何实现。
有三种方案:
第一种使用like:
SELECT * FROM t_mcde_additional_policy t WHERE t.`policyNo` LIKE '801000000080721 ';
- 1
第二种使用关键字 binary:
SELECT * FROM t_mcde_additional_policy t WHERE t.`policyNo` = BINARY'801000000080721';
- 1
第三种使用length函数:
SELECT * FROM t_mcde_additional_policy t WHERE t.`policyNo` = '801000000080721 ' AND LENGTH(t.`policyNo`) = LENGTH('801000000080721 ');
- 1
- 2
以上三种都可以。