MySQL - Почему правила COLLATION игнорируются оператором LIKE для немецкого символа ß - PullRequest
10 голосов
/ 27 октября 2011

Я выполняю следующие операторы select в MySQL 5.0.88 с набором символов utf8 и сопоставлением utf8_unicode_ci:

SELECT * FROM table WHERE surname = 'abcß';

+----+-------------------+------+
| id | forename    | surname    |
+----+-------------------+------+
|  1 | a           | abcß       |
|  2 | b           | abcss      |
+----+-------------+------------+

SELECT * FROM table WHERE surname LIKE 'abcß';

+----+-------------------+------+
| id | forename    | surname    |
+----+-------------------+------+
|  1 | a           | abcß       |
+----+-------------+------------+

Согласно http://dev.mysql.com/doc/refman/5.0/en/charset-unicode-sets.html немецкому специальному символуß = ss для utf8_unicode_ci, но почему он работает только с оператором "=", а не с LIKE?У меня есть приложение для телефонной книги, и мне очень нужно, чтобы обе вещи работали вместе.

1 Ответ

10 голосов
/ 27 октября 2011

В соответствии со стандартом SQL LIKE выполняет сопоставление для каждого символа, таким образом, он может давать результаты, отличные от оператора сравнения =:

mysql> SELECT 'ä' LIKE 'ae' COLLATE latin1_german2_ci;
+-----------------------------------------+
| 'ä' LIKE 'ae' COLLATE latin1_german2_ci |
+-----------------------------------------+
|                                       0 |
+-----------------------------------------+
mysql> SELECT 'ä' = 'ae' COLLATE latin1_german2_ci;
+--------------------------------------+
| 'ä' = 'ae' COLLATE latin1_german2_ci |
+--------------------------------------+
|                                    1 |
+--------------------------------------+

Источник: http://dev.mysql.com/doc/refman/5.0/en/string-comparison-functions.html#operator_like

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...