mysql大小写敏感的一个解决方案
今天,有同事告诉我,我们游戏登陆的时候,账号和密码没有区分大小写,后来又发现创建账号和角色也没有区分大小写。思考登陆流程之后,应该是Mysql没有区分大小写敏感的问题。 在网上查了一下资料,Mysql支持大小写敏感的解决方案。发现了几种方案。 第一、
今天,有同事告诉我,我们游戏登陆的时候,账号和密码没有区分大小写,后来又发现创建账号和角色也没有区分大小写。思考登陆流程之后,应该是Mysql没有区分大小写敏感的问题。
在网上查了一下资料,Mysql支持大小写敏感的解决方案。发现了几种方案。
第一、修改数据库的设置,让Mysql支持大小写敏感,这个方案太激进了,数据库数据太多,这样改保不准会出什么问题。
第二、修改表结构和字符集,和第一种方案差不多,但是风险小一点。
第三、修改存储过程或者SQL语句,好处是不动数据库结构,缺点是涉及到的地方都的改。
权衡之后,还是选了第三种方案,只修改登录和创建的2个存储过程。
体方法是,使用mysql的binary关键字。
BINARY不是函数,是类型转换运算符,它用来强制它后面的字符串为一个二进制字符串,,可以理解为在字符串比较的时候区分大小写。
测试如下:
mysql> select binary 'ABCD'='abcd' ret1, 'ABCD'='abcd' ret2;
+--------+--------+
| ret1 | ret2 |
+--------+--------+
| 0 | 1 |
+--------+--------+
1 row in set (0.00 sec)
下一篇: PHP中间件--ICE
推荐阅读
-
Mysql中返回一个数据库的所有表名,列名数据类型备注_MySQL
-
2020面试准备12----如何把一个字符串的大小写取反(大写变小写或小写变大写)
-
MySql安装步骤图文教程及中文乱码的解决方案
-
mysql连接的空闲时间超过8小时后 MySQL自动断开该连接解决方案
-
利用MySQL加密函数保护Web网站敏感数据的方法分享
-
MySQL 删除大表的性能问题解决方案
-
MAC上Mysql忘记Root密码或权限错误的快速解决方案
-
MySQL多线程复制遇到Error_code: 1872的解决方案
-
MYSQL不能从远程连接的一个解决方法(s not allowed to connect to this MySQL server)
-
MySQL关于exists的一个bug