Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Проблема с PDO и Хранимой процедуры

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
fdr21
Отправлено: 26 Апреля, 2013 - 11:14:02
Post Id



Гость


Покинул форум
Сообщений всего: 86
Дата рег-ции: Июнь 2012  


Помог: 5 раз(а)




Есть простая процедура возвращающую дату
CODE (SQL):
скопировать код в буфер обмена
  1. CREATE PROCEDURE workpan.p(OUT date DATETIME)
  2.   SQL SECURITY INVOKER
  3. BEGIN
  4.   SELECT now() INTO date ;
  5. END
  6.  


Есть код php
... подключение и всё такое

и при
PHP:
скопировать код в буфер обмена
  1. $sql = 'call p(?)';
  2. $stmt = $this->getDB()->prepare($sql);
  3.  
  4. $stmt->bindParam(1, $date, PDO::PARAM_STR);
  5. $stmt->execute();
  6.  
  7. var_dump($date);exit();


Выдаёт ошибку
CODE (htmlphp):
скопировать код в буфер обмена
  1. SQLSTATE[42000]: Syntax error or access violation: 1414 OUT or INOUT argument 1 for routine workpan.p is not a variable or NEW pseudo-variable in BEFORE trigger


в мануале написано что так можно получить выходной параметр, но почему то не получается
CODE (SQL):
скопировать код в буфер обмена
  1. call p(?) хочет получить переменную, что то вроде call p(@var)


Что делать, хочу использовать это как в мануале Улыбка
Может какие либо настройки нужны прикрутить или же PDO старый что ли ...
 
 Top
EuGen Администратор
Отправлено: 26 Апреля, 2013 - 12:09:41
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


Помог: 707 раз(а)




Ну так и передавайте как SQL-переменную. Передав $date (в которой, подозреваю, обычный текст) - Вы передаёте обычный строковый литерал с точки зрения процедуры.


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
fdr21
Отправлено: 26 Апреля, 2013 - 12:28:30
Post Id



Гость


Покинул форум
Сообщений всего: 86
Дата рег-ции: Июнь 2012  


Помог: 5 раз(а)




EuGen пишет:
Ну так и передавайте как SQL-переменную. Передав $date (в которой, подозреваю, обычный текст) - Вы передаёте обычный строковый литерал с точки зрения процедуры.

Вы имеете в виду
PHP:
скопировать код в буфер обмена
  1.  
  2. // присвоить в $date SQL переменную @var
  3. $date = '@var';
  4. $stmt->bindParam(1, $date, PDO::PARAM_STR);
  5. $stmt->execute();
  6.  

так ведь не получится, ведь PDO в call p(?) поставит call p('@var') @var в кавычках!!!
 
 Top
EuGen Администратор
Отправлено: 26 Апреля, 2013 - 12:42:15
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


Помог: 707 раз(а)




Нет.
PHP:
скопировать код в буфер обмена
  1. $stmt->bindParam(1, $date, PDO::PARAM_STR|PDO::PARAM_INPUT_OUTPUT);


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
fdr21
Отправлено: 26 Апреля, 2013 - 12:47:24
Post Id



Гость


Покинул форум
Сообщений всего: 86
Дата рег-ции: Июнь 2012  


Помог: 5 раз(а)




EuGen пишет:
Нет.
PHP:
скопировать код в буфер обмена
  1. $stmt->bindParam(1, $date, PDO::PARAM_STR|PDO::PARAM_INPUT_OUTPUT);

Так тоже пробовал, такая же ошибка Недовольство, огорчение
 
 Top
EuGen Администратор
Отправлено: 26 Апреля, 2013 - 13:04:25
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


Помог: 707 раз(а)






-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
fdr21
Отправлено: 26 Апреля, 2013 - 13:16:45
Post Id



Гость


Покинул форум
Сообщений всего: 86
Дата рег-ции: Июнь 2012  


Помог: 5 раз(а)




EuGen пишет:

Спасибо, а я то думал что у меня ошибку выводит. Видимо в MySQL еще так нельзя использовать, печально ...
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Работа с СУБД »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB