Las comparaciones no distinguen entre mayúsculas y minúsculas cuando la columna usa una clasificación que termina con _ci
(como la clasificación predeterminada latin1_general_ci
) y distinguen entre mayúsculas y minúsculas cuando la columna usa una clasificación que termina con _cs
o _bin
(como las clasificaciones utf8_unicode_cs
y utf8_bin
).
Comprobar colación
Puede verificar su servidor , base de datos y colaciones de conexión usando:
mysql> show variables like '%collation%';
+----------------------+-------------------+
| Variable_name | Value |
+----------------------+-------------------+
| collation_connection | utf8_general_ci |
| collation_database | latin1_swedish_ci |
| collation_server | latin1_swedish_ci |
+----------------------+-------------------+
y puede verificar la clasificación de su tabla 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 |
Cambiar colación
Puede cambiar la clasificación de su base de datos, tabla o columna a algo sensible a mayúsculas y minúsculas de la siguiente manera:
-- 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;
Sus comparaciones ahora deben ser sensibles a mayúsculas y minúsculas.