Порівняння чутливі до регістру , якщо стовпець використовує параметри сортування , який закінчується _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;
Ваші порівняння тепер мають залежно від регістру.