- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在用 php 和 html 编写登录脚本。用户名和密码不需要加密,所以我试图将它们直接存储到数据库 (MySQL) 中。
但我的一些用户的用户名和密码包含特殊字符,如“é”,并且必须区分大小写。
我有这张表:
用户用户名:“ÉleCTeur”,密码:“ÉleCTeur”,用户名:“保罗”,密码:“保罗”
我尝试了这个查询,它对“Paul”工作正常,但对“ÉleCTeur”没有返回任何内容。
SELECT
username,
password
FROM
user
WHERE
BINARY username = 'ÉleCTeur'
AND BINARY password = 'ÉleCTeur'
我是不是错过了什么或者 BINARY
没有比较特殊字符?我可以使用什么方法来解决这个问题?
最佳答案
您的数据库和客户端程序之间的编码可能不一致?
我花了一些时间从 MySQL CLI 进行测试:
mysql> create TABLE user (username CHAR(20), password CHAR(20)) DEFAULT CHARSET=latin1 DEFAULT COLLATE=latin1_general_ci;
Query OK, 0 rows affected (0.25 sec)
mysql> insert into user value("ÉleCTeur", "ÉleCTeur");
Query OK, 1 row affected (0.00 sec)
mysql> select * from user;
+----------+----------+
| username | password |
+----------+----------+
| ÉleCTeur | ÉleCTeur |
+----------+----------+
1 row in set (0.00 sec)
mysql> select count(*) from user where username = "EleCTeur" and password = "EleCteur";
+----------+
| count(*) |
+----------+
| 0 |
+----------+
1 row in set (0.00 sec)
mysql> select count(*) from user where username = "ÉleCTeur" and password = "ÉleCteur";
+----------+
| count(*) |
+----------+
| 1 |
+----------+
1 row in set (0.00 sec)
编辑: 好的,这是一个(太)快速和(太)肮脏的测试。正如 Sebastien 所注意到的,我在这里使用不区分大小写 排序规则。所以:
mysql> select count() from user where username = "éleCTeur"和 password = "éleCteur";+----------+|数() |+----------+| 1 |+----------+一组中的 1 行(0.01 秒)
这里真正的答案是使用区分大小写 (_cs
) 排序规则。要知道哪一个可用:
mysql> show collation where collation like '%_cs';
+--------------------+---------+----+---------+----------+---------+
| Collation | Charset | Id | Default | Compiled | Sortlen |
+--------------------+---------+----+---------+----------+---------+
| latin1_general_cs | latin1 | 49 | | Yes | 1 |
| latin2_czech_cs | latin2 | 2 | | Yes | 4 |
| cp1250_czech_cs | cp1250 | 34 | | Yes | 2 |
| latin7_estonian_cs | latin7 | 20 | | Yes | 1 |
| latin7_general_cs | latin7 | 42 | | Yes | 1 |
| cp1251_general_cs | cp1251 | 52 | | Yes | 1 |
+--------------------+---------+----+---------+----------+---------+
6 rows in set (0.01 sec)
在我的 Debian MySQL 默认安装中它们并不多。
令人惊讶的是,没有 'utf8_cs' !
但是MySQL有_bin
校对也。对订购不是很有用,但对搜索来说已经足够了:
mysql> show collation where collation like '%_bin';
+--------------+----------+----+---------+----------+---------+
| Collation | Charset | Id | Default | Compiled | Sortlen |
+--------------+----------+----+---------+----------+---------+
| big5_bin | big5 | 84 | | Yes | 1 |
| dec8_bin | dec8 | 69 | | Yes | 1 |
| cp850_bin | cp850 | 80 | | Yes | 1 |
| hp8_bin | hp8 | 72 | | Yes | 1 |
| koi8r_bin | koi8r | 74 | | Yes | 1 |
| latin1_bin | latin1 | 47 | | Yes | 1 |
| latin2_bin | latin2 | 77 | | Yes | 1 |
| swe7_bin | swe7 | 82 | | Yes | 1 |
| ascii_bin | ascii | 65 | | Yes | 1 |
| ujis_bin | ujis | 91 | | Yes | 1 |
| sjis_bin | sjis | 88 | | Yes | 1 |
| hebrew_bin | hebrew | 71 | | Yes | 1 |
| tis620_bin | tis620 | 89 | | Yes | 1 |
| euckr_bin | euckr | 85 | | Yes | 1 |
| koi8u_bin | koi8u | 75 | | Yes | 1 |
| gb2312_bin | gb2312 | 86 | | Yes | 1 |
| greek_bin | greek | 70 | | Yes | 1 |
| cp1250_bin | cp1250 | 66 | | Yes | 1 |
| gbk_bin | gbk | 87 | | Yes | 1 |
| latin5_bin | latin5 | 78 | | Yes | 1 |
| armscii8_bin | armscii8 | 64 | | Yes | 1 |
| utf8_bin | utf8 | 83 | | Yes | 1 |
| ucs2_bin | ucs2 | 90 | | Yes | 1 |
| cp866_bin | cp866 | 68 | | Yes | 1 |
| keybcs2_bin | keybcs2 | 73 | | Yes | 1 |
| macce_bin | macce | 43 | | Yes | 1 |
| macroman_bin | macroman | 53 | | Yes | 1 |
| cp852_bin | cp852 | 81 | | Yes | 1 |
| latin7_bin | latin7 | 79 | | Yes | 1 |
| cp1251_bin | cp1251 | 50 | | Yes | 1 |
| cp1256_bin | cp1256 | 67 | | Yes | 1 |
| cp1257_bin | cp1257 | 58 | | Yes | 1 |
| geostd8_bin | geostd8 | 93 | | Yes | 1 |
| cp932_bin | cp932 | 96 | | Yes | 1 |
| eucjpms_bin | eucjpms | 98 | | Yes | 1 |
+--------------+----------+----+---------+----------+---------+
35 rows in set (0.00 sec)
在下面的示例中,我使用 utf8 编码和 utf8_bin 排序规则创建了一个表。请注意,您可以改为在每列的基础上更改编码/排序规则。
mysql> create TABLE user (username CHAR(20), password CHAR(20)) DEFAULT CHARSET=utf8 DEFAULT COLLATE=utf8_bin;
Query OK, 0 rows affected (0.26 sec)
mysql> insert into user value("ÉleCTeur", "ÉleCTeur");
Query OK, 1 row affected (0.00 sec)
mysql> select count(*) from user where username = "ÉleCTeur" and password="ÉleCTeur";
+----------+
| count(*) |
+----------+
| 1 |
+----------+
1 row in set (0.00 sec)
mysql> select count(*) from user where username = "éleCTeur" and password="éleCTeur";
+----------+
| count(*) |
+----------+
| 0 |
+----------+
1 row in set (0.01 sec)
关于MySQL SELECT 语句区分大小写和特殊字符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17555790/
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求提供代码的问题必须表现出对所解决问题的最低限度理解。包括尝试过的解决方案、为什么它们不起作用,以及预
出于某种原因,右栏中的精选文章忽略了“#elementtext”和“#elementtext:hover”属性。仅显示“p.element”和“img.element”。 有什么想法吗? 谢谢 - 塔
我有两个值,每个值都来自不同的枚举。我想检查这两者的允许组合,如果没有找到则执行默认操作。我能以某种方式对这两个值进行切换/大小写吗?我想避免使用多个 if/else 语句或遵循位掩码模式的枚举,只是
我需要 where 但 not 大小写。例如,我想找到没有名字“莎士比亚”的戏剧: _.where(listOfPlays, {author: !"Shakespeare", year: 1611})
我想实现一个 parking 场应用所以有一个带5个或更多 parking 位的车库当司机 parking 时,车库中的下一个空闲位置应该分配给他。 所以我有一个带 5 个或更多插槽的 table 上
我想使用 Erlang 来确定传递给函数的变量是否可以被数字整除。我考虑过使用 case 来执行此操作,但是我找不到解决方案。 case 是适合这项工作的工具吗? 示例:将数字传递给函数 f()。如果
我在 phpmyadmin 中创建了一个表,其列名如 first_name、last_name。当我使用命令显示表中的列名时,它会将它们显示为 first_name。 我想显示我的列名称,如 Firs
使用 Swift 4,如何使用这些规则格式化字符串: 如果单词超过 3 个字母,则首字母大写,否则大写 包含像 St-Michel 这样的连字符的 Pascal 大小写单词 我这里有初稿,但我一直在思
这个问题在这里已经有了答案: Why can't the switch statement be applied to strings? (23 个回答) 关闭 8 年前。 大家好 所以我正在尝试对
在 MVC 操作中,我如何访问使用多个同名值提交的“表单数据”中的值? 我做了什么:int、decimal、string 类型的值工作完美。 问题:每个变体都有一个复选框,所以当我尝试获取它时,它只显
while(1) { char buff[1000]; printf("Enter the word: "); fgets(buff, 1000
我有一个 Dllmain,它在线程附加到此 DLL 时分配线程本地存储。代码如下: BOOL APIENTRY DllMain(HMODULE hModule,
我有一个变量名,比如“WARD_VS_VITAL_SIGNS”,我想将它转换为 Pascal 大小写格式:“WardVsVitalSigns” WARD_VS_VITAL_SIGNS -> WardV
我是 Swift 编码的新手,正在尝试弄清楚如何在触摸节点时制作具有开/关功能的循环音频。我认为实现它的最佳方式是通过 SKAudioNode,但我不确定我在以下代码中做错了什么。当在节点上按下时 -
这是我第一次使用这种枚举,具有关联值类型的枚举,我需要根据对象的类型制作一个 switch 语句,我无法做到,这是枚举: enum TypeEnum { case foo(FooClass)
我想从字符串中删除所有下划线,下划线后面的字符为大写。因此,例如:_my_string_ 变为:MyString 同样:my_string 变为 MyString 有没有更简单的方法呢?我目前有以下内
如何在 Java 中将蛇形大小写转换为 Camel 形大小写? 输入:“input_in_snake_case” 输出:“InputInSnakeCase” 最佳答案 Guava通过其CaseForm
我们有一个表auth_group_access,那么如何使用呢? 在使用M方法时,对于带下划线的表名,可以采用如下方法。 M('AuthGroupAccess'); 对应sql语句SQL: S
我正在制作一个 pygame 游戏,每当我运行我的代码时,我都会收到错误 expected ':'。我知道在 match/case block 中使用 [ 和 ] 用于其他用途,但我该如何解决这个问题
有人能告诉我是否可以使用正则表达式将 url 转换为小写? 这是在 html img 标签内,所以我们可以通过标签找到网址。 这是我所拥有的一个例子 我需要在最后小写图像名称。 该文档包含更多 H
我是一名优秀的程序员,十分优秀!