Правила     Закладки     Карма    Календарь    Журналы    Помощь    Поиск    PDA    Чат   
        СМС-ки
   
Пейджер выключен!
 
Фильтр авторов:    показать 
  скрыть
  Ответ в темуСоздание новой темыСоздание опроса

> PDO множественная вставка
maruo  
 ۩  [x] Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Здесь живет
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 324
Пользователь №: 37433
На форуме: 3 года, 6 месяцев, 22 дня
Карма: 1




Ошибка такая
DO SQL ERROR: SQLSTATE[HY093]: Invalid parameter number: number of bound variables does not match number of tokens
Что означает знаю.
Но когда я вручную подставляю данные они проходят, а когда через переменую то нет

$link = PDO_DataBase::getInstance()->getConnection();


$new_max_win = 2;
$lot_id = 5;

$param = null;
$n = null;

for ($f=0; $f < $new_max_win; $f++) {
$cods = generate_string(10);

$n .= "(?,?),";
$cols = substr($n, 0, -1);

$param .= "'$lot_id','$cods',";
$arr_cods = substr($param, 0, -1);
}



echo $arr_cods ;

$sql = "INSERT INTO promo_cods (lot_id,code) VALUES $cols";
$params = array( 5,'s1m3c1m4x1',5,'n5f1l5g2z3');
$result = singleUpdate($link,$sql,$params);

$params = array( 5,'s1m3c1m4x1',5,'n5f1l5g2z3');//Вот так работает.

$arr_cods = '5','s1m3c1m4x1','5','n5f1l5g2z3';//А вот так нет
$params = array($arr_cods);


  function singleUpdate($conObject,$sql,$params){
if(!is_array($params)){
$params = array($params);
}
try{
$process = $conObject->prepare($sql);
$process->execute($params);
if($process->rowCount() == 0){
$data = array('info' => 'SQL return 0 row');
}else{
$data = array('success' => 'Success Update');
}
}
catch(PDOException $e){
die("PDO SQL ERROR: " . $e->getMessage() . "<br/>");
}
$process->closeCursor();
return $data;
}


Это сообщение отредактировал maruo - 13.05.2016 - 01:50
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
maruo  
 ۩  Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Здесь живет
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 324
Пользователь №: 37433
На форуме: 3 года, 6 месяцев, 22 дня
Карма: 1






Вопрос Решил
$params = explode(",", $arr_cods);
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
bestxp  
Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



орангутанг
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 2004
Пользователь №: 36605
На форуме: 3 года, 9 месяцев, 17 дней
Карма: 111




а зачем тебе там die ?
ну что за привычка дурная? по рукам надавать у тебя уже есть return, вот и сделай

return [ 'error' => 'Бла бла бла' ] и нормально выведешь ошибку уже пользователю, а не die


--------------------
PMПисьмо на e-mail пользователюСайт пользователяICQ
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
maruo  
 ۩  Дата
Цитировать сообщение

Пользователя сейчас нет на форуме



Здесь живет
******

Профиль
Группа: Форумчанин
Завсегдатай форума
Сообщений: 324
Пользователь №: 37433
На форуме: 3 года, 6 месяцев, 22 дня
Карма: 1




bestxp
Объясни почему нельзя Die или статью скинь мне интересно!
PMПисьмо на e-mail пользователю
    0   Для быстрого поиска похожих сообщений выделите 1-2 слова в тексте и нажмите сюда Для быстрой цитаты из этого сообщения выделите текст и нажмите сюда
  Быстрый ответ
Информация о Госте
Введите Ваше имя
Кнопки кодов
Для вставки цитаты, выделите нужный текст и
НАЖМИТЕ СЮДА
Введите сообщение
Смайлики
:huh:  :o  ;) 
:P  :D  :lol: 
B)  :rolleyes:  <_< 
:)  :angry:  :( 
:unsure:  :blink:  :ph34r: 
     
Показать всё

Опции сообщения  Включить смайлики?
 Включить подпись?
 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:

Опции темы Ответ в темуСоздание новой темыСоздание опроса