IN (?,?) Точные значения подготовленных операторов mysqliPhp

Кемеровские программисты php общаются здесь
Ответить Пред. темаСлед. тема
Anonymous
 IN (?,?) Точные значения подготовленных операторов mysqli

Сообщение 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 ));


Подробнее здесь: https://stackoverflow.com/questions/483 ... ise-values
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение
  • Как пакетно изменить множество процедурных запросов mysqli для подготовленных операторов?
    Anonymous » » в форуме Php
    0 Ответы
    16 Просмотры
    Последнее сообщение Anonymous
  • Как написать модульный тест PHP для подготовленных операторов mysqli?
    Anonymous » » в форуме Php
    0 Ответы
    17 Просмотры
    Последнее сообщение Anonymous
  • Как написать модульный тест PHP для подготовленных операторов mysqli?
    Anonymous » » в форуме Php
    0 Ответы
    10 Просмотры
    Последнее сообщение Anonymous
  • Как написать модульный тест PHP для подготовленных операторов mysqli?
    Anonymous » » в форуме Php
    0 Ответы
    14 Просмотры
    Последнее сообщение Anonymous
  • Несколько подготовленных операторов в PHP с MySQLi
    Anonymous » » в форуме Php
    0 Ответы
    10 Просмотры
    Последнее сообщение Anonymous

Вернуться в «Php»