Преобразование в символ CHAR приводит к тому, что индекс столбца VARCHAR не работает

Многие объяснения уже присутствуют, чтобы объяснить, как это происходит и как это исправить, но вы также должны следовать рекомендациям, чтобы избежать NullPointerException вообще.

См. также: A хороший список лучших практик

Я бы добавил, очень важно, хорошо использовать модификатор final. Использование "окончательной" модификатор, когда это применимо в Java

Сводка:

  1. Используйте модификатор final для обеспечения хорошей инициализации.
  2. Избегайте возврата null в методы, например, при возврате пустых коллекций.
  3. Использовать аннотации @NotNull и @Nullable
  4. Быстрое завершение работы и использование утверждений, чтобы избежать распространения нулевых объектов через все приложение, когда они не должен быть пустым.
  5. Сначала используйте значения с известным объектом: if("knownObject".equals(unknownObject)
  6. Предпочитают valueOf() поверх toString ().
  7. Используйте null safe StringUtils StringUtils.isEmpty(null).

2
задан Neo 15 January 2019 в 14:00
поделиться

1 ответ

Похоже на проблему CHARACTER SET или COLLATION. Пожалуйста, предоставьте:

SHOW VARIABLES LIKE 'char%';
how you are connecting to the database
SHOW CREATE TABLE table1;

Вероятно, ответ включает изменение CONVERT:

CONVERT(1, CHAR  charset utf8)

Что такое реальный запрос; может быть какой-то другой подход, который лучше для вашей ситуации. Использование CONVERT - кладжа; давайте перейдем к необходимости.

Чтобы увидеть преобразование (я), сделайте

EXPLAIN FORMAT=JSON SELECT ...
0
ответ дан Rick James 15 January 2019 в 14:00
поделиться
Другие вопросы по тегам:

Похожие вопросы: