Мы столкнулись с этой проблемой при попытке добавить индекс UNIQUE в поле VARCHAR (255) с помощью utf8mb4. Несмотря на то, что проблема уже хорошо изложена, я хотел бы добавить несколько практических советов, как мы это выяснили и решили.
При использовании utf8mb4 символы считаются как 4 байта, тогда как при utf8 они могут быть как 3 байта. Базы данных InnoDB имеют ограничение, что индексы могут содержать только 767 байтов. Поэтому при использовании utf8 вы можете хранить 255 символов (767/3 = 255), но при использовании utf8mb4 вы можете хранить только 191 символ (767/4 = 191).
Вы абсолютно можете добавить обычные индексы для VARCHAR(255)
полей, используя utf8mb4, но в этом случае размер индекса автоматически усекается до 191 символа - как unique_key
здесь:
Это хорошо, потому что обычные индексы просто используются, чтобы помочь MySQL быстрее искать ваши данные. Целое поле не нужно индексировать.
Итак, почему MySQL автоматически усекает индекс для обычных индексов, но выдает явную ошибку при попытке сделать это для уникальных индексов? Что ж, для того, чтобы MySQL мог определить, существует ли уже добавляемое или обновляемое значение, ему нужно индексировать целое значение, а не только его часть.
В конце дня, если вы хотите иметь уникальный индекс для поля, все содержимое поля должно вписываться в индекс. Для utf8mb4 это означает уменьшение длины поля VARCHAR до 191 символа или менее. Если вам не нужен utf8mb4 для этой таблицы или поля, вы можете сбросить его обратно до utf8 и сохранить свои поля длиной 255.