Сравнения нечувствительны к регистру, когда столбец использует параметры сортировки, которые заканчиваются на _ci
(например, параметры latin1_general_ci
сортировки по умолчанию ), и они чувствительны к регистру, когда столбец использует параметры сортировки, которые заканчиваются на _cs
или _bin
(такие как utf8_unicode_cs
иutf8_bin
сортировки).
Проверьте сопоставление
Вы можете проверить параметры сортировки вашего сервера , базы данных и соединений, используя:
mysql> show variables like '%collation%';
+----------------------+-------------------+
| Variable_name | Value |
+----------------------+-------------------+
| collation_connection | utf8_general_ci |
| collation_database | latin1_swedish_ci |
| collation_server | latin1_swedish_ci |
+----------------------+-------------------+
и вы можете проверить свою таблицу сортировки с помощью:
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 |
Изменить параметры сортировки
Вы можете изменить параметры сортировки базы данных, таблицы или столбца на следующие с учетом регистра:
-- 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;
Ваши сравнения должны теперь быть чувствительными к регистру.