MySQL中关于查询条件中的字符串空格问题
2013-08-29 11:35
696 查看
假设当前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。
官方:http://dev.mysql.com/doc/refman/5.5/en/char.html
有个字段是: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。
官方:http://dev.mysql.com/doc/refman/5.5/en/char.html
相关文章推荐
- MySQL中关于查询条件中的字符串空格问题
- MySQL中关于查询条件中的字符串空格问题
- MySQL查询条件中字符串包含空格的问题
- 关于Mysql查询带单引号及插入带单引号字符串问题
- MySQL查询时的字符串空格问题
- 关于MYSQL查询时WHERE条件值为数字的问题
- 关于MYSQL查询时WHERE条件值为数字的问题
- 关于Mysql查询带单引号及插入带单引号字符串问题
- 关于Mysql查询带单引号及插入带单引号字符串问题
- mysql 查询条件不区分大小写问题
- MySQL 实现树形的遍历(关于多级菜单栏以及多级上下部门的查询问题)
- 关于MongoDB的多条件查询问题
- mysql 关于查询时间的中工作中遇到的一些问题 有代表性的
- MySQL种字符串拆分(substring_index)并作为关联查询条件后多列展示
- 解决mysql查询,in条件参数为带逗号的字符串,查询结果错误
- 转发:[MySQL] 实现树形的遍历(关于多级菜单栏以及多级上下部门的查询问题)
- 关于php查询字符串中带点号的问题
- Oracle、Mysql、MS sql中关于模糊查询问题
- 关于PHP 查询 mysql 乱码问题解决方式
- MySQL种字符串拆分(substring_index)并作为关联查询条件后多列展示