Java基础、中级、高级、架构面试资料

MySQL 中,为什么有些数据库在匹配字符时不区分大小写?

SQL herman 2506浏览
公告:“业余草”微信公众号提供免费CSDN下载服务(只下Java资源),关注业余草微信公众号,添加作者微信:xttblog2,发送下载链接帮助你免费下载!
本博客日IP超过2000,PV 3000 左右,急需赞助商。
极客时间所有课程通过我的二维码购买后返现24元微信红包,请加博主新的微信号:xttblog2,之前的微信号好友位已满,备注:返现
受密码保护的文章请关注“业余草”公众号,回复关键字“0”获得密码
所有面试题(java、前端、数据库、springboot等)一网打尽,请关注文末小程序
视频教程免费领
腾讯云】1核2G5M轻量应用服务器50元首年,高性价比,助您轻松上云

这其实是一个小问题,但小问题往往是一个高频问题。我敢打赌,很多网站的数据库设计者可能都没有注意这个细节。不信,你去试一试大多数网站的登录,账号如果是邮箱,或者是名称的,你可以看看是否区分大小写!

造成这个问题的原因是,我们经常再讲 select、insert 之类的 SQL 语句,而对于创建数据库,表之类的一些常规配置项还不太理解。通常你在看书,或者是老师教你时,在创建数据库时,直接说选择默认的就可以。一笔带过!

创建数据库

最熟悉的陌生人!往往是这个一笔带过把我们带到坑里了。因为我们在创建表或数据库的时候,默认的排序规则就是不区分大小写的。

MySQL 有很多默认的排序规则的,并且不同的字符集有不同的排序规则,但它们也是有规律可循的。我们可以通过下面的 SQL 语句来查看对应字符集的默认排序规则。

SHOW COLLATION LIKE 'utf8\_%';
SHOW COLLATION LIKE ‘utf8_%’;

这个 Collation 其实非常的有规律。第一个“-”前面是对应的字符集;中间是语言,各个国家支持的语言;最后面的”ci”代表比较规则。

MySQL字符集排序规则

如果你默认选择的是 utf8_general_ci,或者是 xx_general_ci,那它就不会区分大小写。想要区分大小写,就要选择以”_cs”结尾的排序规则。

以上,希望能够帮助大家解决一些实际工作中的问题。

业余草公众号

最后,欢迎关注我的个人微信公众号:业余草(yyucao)!可加作者微信号:xttblog2。备注:“1”,添加博主微信拉你进微信群。备注错误不会同意好友申请。再次感谢您的关注!后续有精彩内容会第一时间发给您!原创文章投稿请发送至532009913@qq.com邮箱。商务合作也可添加作者微信进行联系!

本文原文出处:业余草: » MySQL 中,为什么有些数据库在匹配字符时不区分大小写?