Подготовленные операторы для меня сложны с предложениями IN(). У меня есть инструкция для вызова Ajax, в которой $_POST представляет собой массив значений.
У меня есть строка из трех значений «1, 2, 3», которую я разбиваю, чтобы подсчитать значение для предложения привязки (?) и строки привязки (s или i ).
Я изо всех сил пытаюсь получить правильные параметры связывания. Запрос не работает, если значения передаются в виде строки за один раз. например:
$values = "1, 2, 3";
$bindString = "sss";
$stmt->bind_param($bindString, $values);
Он работает, если передается как отдельные значения, например:
$value1 = "1";
$value2 = "2";
$value3 = "3";
$stmt->bind_param($bindString, $value1, $value2, $value3 );
Глядя на var_dump(), я вижу, что тип значения отображается, когда каждое из значений вводится как отдельная переменная. Но я не уверен, является ли это причиной того, почему я не могу заставить работать строку, передаваемую через одну переменную. Мне очень сложно понять правильный формат, который требуется.
Поскольку этот запрос является динамическим и будет иметь много разных значений, мне нужно, чтобы он работал хорошо и был безопасно подготовлен. Поэтому мне нужен лучший способ подготовить значения, переданные из сообщения AJAX, для доставки их в подготовленный оператор.
Я просмотрел другие сообщения, чтобы попытаться найти способ подготовки операторов с помощью IN(), и у меня это почти получилось, но я думаю, что большая трудность связана с доставкой этих значений.
Если кто-то может помочь мне понять эта правильная передача ценностей, я думаю, я был бы в гораздо лучшем положении: я надеюсь, что это станет последним препятствием на пути к тому, чтобы это заработало. У меня есть еще несколько запросов с «IN()», которые нужно подготовить. Надеюсь, я не буду тратить еще один день, пытаясь разобраться в этом. Заранее спасибо.
примечание: просто чтобы уточнить: я думаю, что подготовка для строки связывания и предложения в порядке.
$bindClause = implode(',', array_fill(0, count( $values ), '?'));
$bindString = str_repeat('s', count( $values ));
Подробнее здесь: https://stackoverflow.com/questions/483 ... ise-values
IN (?,?) Точные значения подготовленных операторов mysqli ⇐ Php
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение
-
-
Как пакетно изменить множество процедурных запросов mysqli для подготовленных операторов?
Anonymous » » в форуме Php - 0 Ответы
- 16 Просмотры
-
Последнее сообщение Anonymous
-