MySQL 如何执行区分大小写的字符串比较?
众所周知,比较字符时 MySQL 并不区分大小写,但可以更改,即如果我们在表达式之前使用 BINARY 关键字,MySQL 可以执行区分大小写的字符串比较。事实上,BINARY 关键字指示 MySQL 使用字符串中字符的底层 ASCII 值而不是仅使用其字母来比较字符串中的字符。以下来自包含以下数据的表“Employee”的示例对此进行了说明:
mysql> Select * from Employee; +----+--------+--------+ | ID | Name | Salary | +----+--------+--------+ | 1 | Gaurav | 50000 | | 2 | Rahul | 20000 | | 3 | Advik | 25000 | | 4 | Aarav | 65000 | | 5 | Ram | 20000 | | 6 | Mohan | 30000 | | 7 | Aryan | NULL | | 8 | Vinay | NULL | +----+--------+--------+ 8 rows in set (0.09 sec)
下面的查询将使用 BINARY 关键字强制 MySQL 执行区分大小写的字符串比较。
mysql> Select * from Employee WHERE BINARY Name IN ('Gaurav','RAM'); +----+--------+--------+ | ID | Name | Salary | +----+--------+--------+ | 1 | Gaurav | 50000 | +----+--------+--------+ 1 row in set (0.00 sec)
广告