Задать вопрос
@NataliaCh

Почему возникает ошибка в подготовленном выражении?

если делаю так
$string = "'%бла-бла%', '%бла-бла%', '%бла-бла%'";    
$rs->execute(array($string));

То возникает ошибка
PDOException: SQLSTATE[HY093]: Invalid parameter number: number of bound variables does not match number of tokens

Если же тупо подставляю тоже самое в выражение
$rs->execute(array('%бла-бла%', '%бла-бла%', '%бла-бла%'));

То ошибки нет.
Что не так?
  • Вопрос задан
  • 29 просмотров
Подписаться 1 Простой Комментировать
Помогут разобраться в теме Все курсы
  • Skillfactory
    Профессия Fullstack веб-разработчик на JavaScript и PHP
    20 месяцев
    Далее
  • Хекслет
    PHP-разработчик
    10 месяцев
    Далее
  • Нетология
    Веб-разработчик с нуля: профессия с выбором специализации
    14 месяцев
    Далее
Решения вопроса 1
gobananas
@gobananas
finishhim.ru
Так вы же строку подставляете туда где должен быть массив. Надо тогда так:
$rs->execute(explode(', ', $string));
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
FoodSoul Калининград
от 180 000 до 250 000 ₽
IT-Spirit Москва
от 230 000 до 320 000 ₽
от 200 000 до 290 000 ₽