Подготовленные операторы для меня сложны с предложениями 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
Кемеровские программисты php общаются здесь
-
Anonymous
1730261783
Anonymous
Подготовленные операторы для меня сложны с предложениями 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 ));
Подробнее здесь: [url]https://stackoverflow.com/questions/48345240/in-prepared-statements-mysqli-precise-values[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия