As comparações diferenciam maiúsculas de minúsculas quando a coluna usa um agrupamento que termina com _ci
(como o agrupamento padrão latin1_general_ci
) e diferenciam maiúsculas de minúsculas quando a coluna usa um agrupamento que termina com _cs
ou _bin
(como os agrupamentos utf8_unicode_cs
e utf8_bin
).
Verificar agrupamento
Você pode verificar seu servidor , banco de dados e agrupamentos de conexão usando:
mysql> show variables like '%collation%';
+----------------------+-------------------+
| Variable_name | Value |
+----------------------+-------------------+
| collation_connection | utf8_general_ci |
| collation_database | latin1_swedish_ci |
| collation_server | latin1_swedish_ci |
+----------------------+-------------------+
e você pode verificar o agrupamento da tabela usando:
mysql> SELECT table_schema, table_name, table_collation
FROM information_schema.tables WHERE table_name = `mytable`;
+----------------------+------------+-------------------+
| table_schema | table_name | table_collation |
+----------------------+------------+-------------------+
| myschema | mytable | latin1_swedish_ci |
Alterar agrupamento
Você pode alterar o agrupamento do banco de dados, tabela ou coluna para algo que diferencia maiúsculas de minúsculas da seguinte maneira:
-- Change database collation
ALTER DATABASE `databasename` DEFAULT CHARACTER SET utf8 COLLATE utf8_bin;
-- or change table collation
ALTER TABLE `table` CONVERT TO CHARACTER SET utf8 COLLATE utf8_bin;
-- or change column collation
ALTER TABLE `table` CHANGE `Value`
`Value` VARCHAR(255) CHARACTER SET utf8 COLLATE utf8_bin;
Suas comparações agora devem fazer distinção entre maiúsculas e minúsculas.