«Если рабочий хочет хорошо выполнять свою работу, он должен сначала заточить свои инструменты» — Конфуций, «Аналитики Конфуция. Лу Лингун»
титульная страница > программирование > Как устранить предупреждение об отсутствующем индексе в подготовленных выражениях MySQL?

Как устранить предупреждение об отсутствующем индексе в подготовленных выражениях MySQL?

Опубликовано 31 октября 2024 г.
Просматривать:793

How to Resolve Missing Index Warning in MySQL Prepared Statements?

Неустранимая ошибка: предупреждение об отсутствии индекса в запросе MySQL

Эта ошибка возникает при выполнении запроса, который использует подготовленный оператор, но не указывает индекс запрашиваемой таблицы. Сервер MySQL выдаст предупреждение о том, что индекс не использовался, что приведет к потенциальным проблемам с производительностью.

В приведенном коде PHP:

$get_emp_list = $mysql->prepare("SELECT id, name FROM calc");

Подготовленный оператор не указывает индекс для таблицы Calc. Чтобы это исправить, вы можете добавить индекс в таблицу, используя следующий оператор SQL:

ALTER TABLE calc ADD INDEX (id);

Альтернативно вы можете указать индекс явно в подготовленном операторе с использованием предложения USING:

$get_emp_list = $mysql->prepare("SELECT id, name FROM calc USING INDEX (id)");

После индекс будет добавлен, запрос будет использовать индекс для более быстрого выполнения и избежать появления предупреждающего сообщения.

Важно отметить, что хотя предупреждение об отсутствующем индексе является незначительной проблемой в MySQL, сопровождающая его ошибка PHP является фатальный. Это связано с тем, что в предоставленном коде для параметра mysqli_report установлено значение MYSQLI_REPORT_ALL, которое сообщает обо всех ошибках и предупреждениях как о фатальных исключениях. Чтобы предотвратить это, вы можете изменить настройку на MYSQLI_REPORT_ERROR или MYSQLI_REPORT_STRICT, которые сообщают только о реальных ошибках как о фатальных.

Заявление о выпуске Эта статья перепечатана по адресу: 1729470616. В случае каких-либо нарушений, пожалуйста, свяжитесь с [email protected], чтобы удалить ее.
Последний учебник Более>

Изучайте китайский

Отказ от ответственности: Все предоставленные ресурсы частично взяты из Интернета. В случае нарушения ваших авторских прав или других прав и интересов, пожалуйста, объясните подробные причины и предоставьте доказательства авторских прав или прав и интересов, а затем отправьте их по электронной почте: [email protected]. Мы сделаем это за вас как можно скорее.

Copyright© 2022 湘ICP备2022001581号-3