• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

如何解决mysql查询不区分大小写问题

mysql 搞java代码 3年前 (2022-05-15) 15次浏览 已收录 0个评论

解决方案一:

设置collate校对。

(推荐教程:mysql数据库学习教程)

collate规则:

 *_bin: 表示的是binary <a href="https://www.gaodaima.com/tag/case" title="查看更多关于case的文章" target="_blank">case</a> sensitive <a href="https://www.gaodaima.com/tag/collation" title="查看更多关于collation的文章" target="_blank">collation</a>,也就是说是区分<a href="https://www.gaodaima.com/tag/%e5%a4%a7%e5%b0%8f%e5%86%99" title="查看更多关于大小写的文章" target="_blank">大小写</a>的
 *_cs: case sensitive collation,区分大小写
 *_ci: case insensitive collation,不区分大小写

www#gaodaima.com来源[email protected]搞@^&代*@码网搞代码

1、可以将查询条件用binary()括起来。  比如:  

select * from TableA where binary columnA ='aaa';

2、可以修改该字段的collation 为 binary

比如:

ALTER TABLE TABLENAME MODIFY COLUMN COLUMNNAME VARCHAR(50) BINARY CHARACTER SET utf8 COLLATE utf8_bin DEFAULT NULL;

解决方案二:

mysql查询默认是不区分大小写的 如:

select * from some_table where str=‘abc';
select * from some_table where str='ABC';

得到的结果是一样的,如果我们需要进行区分的话可以按照如下方法来做: 

第一种方法:

要让mysql查询区分大小写,可以:

select * from some_table where binary str='abc'select * from some_table where binary str='ABC'

第二方法:

在建表时时候加以标识

create table some_table(   str char(20) binary)

原理:

对于CHAR、VARCHAR和TEXT类型,BINARY属性可以为列分配该列字符集的 校对规则。BINARY属性是指定列字符集的二元 校对规则的简写。排序和比较基于数值字符值。因此也就自然区分了大小写。

来源:搞代码网:原文地址:https://www.gaodaima.com


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:如何解决mysql查询不区分大小写问题

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址