Поиск в базе данных MySQL значения надстрочного индекса

У меня есть надстрочный индекс (и другие нестандартные символы) в таблице в моей базе данных. Они хранятся нормально, и я могу видеть их через PHPmyadmin. Однако, если я попытаюсь выполнить поиск через PHP, он не покажет никаких значений и зависнет при поиске.

URL для конкретного https://www.bowling-tracker.com/bowl/bowling-resources/bowling-ball-information

Если вы наберете «Sword» в поле поиска, он должен вернуть 8 результатов, но вместо этого он зависнет.

Если я напечатаю

"SELECT * FROM `ball_model` WHERE NAME LIKE '%Sword%' ORDER BY `modelID` 
DESC"

в phpmyadmin я вижу все результаты. Имя в одном из результатов - Sword C³, и я уверен, что проблема заключается в надстрочном индексе, поскольку другие поисковые запросы работают нормально.

Фактический оператор SQL, отправленный на страницу:

SELECT a.modelID, a.name, b.mfgID, b.name AS MfgName FROM ball_model a LEFT 
JOIN ball_mfg b ON a.mfgID = b.mfgID

который также отлично работает в phpmyadmin

Поэтому я совершенно сбит с толку, почему он зависает при «обработке» при попытке доступа к записям с надстрочным индексом.

Для таблицы установлено значение utf8_general_ci в качестве сопоставления и механизма хранения InnoDB (в случае, если это имеет значение).

Я использую соединение с базой данных pdo, которое включает следующие атрибуты:

$conn = new PDO("mysql:host=$DBhost;charset=utf8mb4", $DBuser, $DBpassword);
$conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$conn->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC);
$conn->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);}

SQL выполняется на стороне сервера, и я использую DataTables для отображения результатов.

Любая помощь будет оценена по достоинству.

вы используете плагин datatables. Этот поиск выполняется на стороне клиента в массиве всех распечатанных и разбитых на страницы записей на стороне клиента. Это не лишний запрос

Lelio Faieta 19.07.2018 17:29

Проверьте журналы ошибок и консоль браузера. Вы видите ошибки?

WillardSolutions 19.07.2018 17:47

Похоже, что для этого есть ошибки в DataTables (в Google DevTools). Я не знаю, как это исправить.

Charles Wilkins IV 19.07.2018 18:10

Lelio - плагин datatables позволяет обрабатывать запросы на стороне сервера.

Charles Wilkins IV 19.07.2018 18:10
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
2
4
87
0

Другие вопросы по теме