MySQL中关于查询条件中的字符串空格问题
2014-11-10 15:09
633 查看
假设当前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。
有个字段是: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。
相关文章推荐
- MySQL中关于查询条件中的字符串空格问题
- MySQL中关于查询条件中的字符串空格问题
- MySQL查询条件中字符串包含空格的问题
- 关于MYSQL查询时WHERE条件值为数字的问题
- 关于Mysql查询带单引号及插入带单引号字符串问题
- 关于Mysql查询带单引号及插入带单引号字符串问题
- MySQL查询时的字符串空格问题
- 关于Mysql查询带单引号及插入带单引号字符串问题
- 关于MYSQL查询时WHERE条件值为数字的问题
- 关于php查询字符串中带点号的问题
- 关于SQL查询的字符串类型字段的排序问题
- mysql 查询条件不区分大小写问题
- MySql数据查询的逻辑蕴含条件问题
- [MySQL] 实现树形的遍历(关于多级菜单栏以及多级上下部门的查询问题)
- 关于 hibernate 逻辑删除 默认查询过滤条件问题(java set 条件)
- 关于处理字符串里姓名中间、前后有空格的问题
- mysql select *... where id in (select 字符串 from ... )查询结果问题?
- mysql查询根据字符串位置排序问题
- C语言:关于计算字符串中空格数的问题
- 关于动态存储分配函数的调用,在已经过排序的数组中查找及删除内容的操作,余数的分析,删除字符数组中的空格,对链表的逆置,在源字符串中查找子字符串的个数,函数指针以及函数的调用,循环赋值带来的问题以及插入