详解Mysql查询条件中字符串尾部有空格也能匹配上的问题

吾爱主题 阅读:145 2024-04-05 16:20:19 评论:0

一、表结构

TABLE person

 

id name
1
2 你(一个空格)
3 你(二个空格)

 

二、查询与结果

?
1 select * from person where ` name ` = ?

无论 ? = ”你 + 几个空格”,都会检索出全部三个结果。

三、原因

MySQL 校对规则属于PADSPACE,会忽略尾部空格

针对的是 varchar char text …… 等文本类的数据类型

此为 SQL 标准化行为。无需要设置也无法改变。

四、想要精确查询怎么办?

方法一:like

?
1 select * from person where ` name ` like ?

方法二:BINARY

?
1 select * from person where ` name ` = BINARY ?

BINARY 不是函数,是类型转换运算符,它用来强制它后面的字符串为一个二进制字符串,可以理解成精确匹配

以上就是本次介绍的全部相关知识点,如果大家有任何补充可以联系服务器之家小编。

原文链接:https://www.cnblogs.com/xjnotxj/p/9019866.html

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容