2015-02-08 3 views
0

Я пытаюсь запустить процедуру, которая принимает параметр «таблица» для запроса и результат в качестве выходного параметра. Тем не менее, он отображается как необъявленная переменная: результатВыходная переменная хранимой процедуры

Я удвоил проверку, не допуская орфографической ошибки, но до сих пор не знаю, как это произошло. Будет ли кто-то просьба предоставить некоторую помощь или руководство

CREATE DEFINER=`root`@`localhost` PROCEDURE `Function`(IN table varchar(10), OUT result varchar (10)) 
BEGIN 

    SET @q = CONCAT (' 
     Select `field` from `',table,'` into result limit 1;'); 


    PREPARE stmt from @q; 
    EXECUTE stmt; 
    DEALLOCATE PREPARE stmt; 

END 

ответ

0

Try:

... 
-- SET @q = CONCAT ('Select `field` from `',table,'` into result limit 1;'); 
SET @`q` := CONCAT('SELECT `der`.`field` 
        FROM (SELECT `field` FROM `', `table`, '` LIMIT 1) `der`, 
         (SELECT @`result` := NULL) `init` 
         INTO @`result`;'); 
PREPARE `stmt` from @`q`; 
EXECUTE `stmt`; 
SET `result` := @`result`; 
DEALLOCATE PREPARE `stmt`; 
... 

Важно указать разницу между 9.4. User-Defined Variables и рутинными параметрами 13.1.15. CREATE PROCEDURE and CREATE FUNCTION Syntax, является различными переменными.

SQL Fiddle demo

+0

Привет показывает: Код ошибки: 1064. У Вас есть ошибка в вашем SQL синтаксиса; проверьте руководство, соответствующее версии сервера MySQL, для правильного синтаксиса для использования рядом с «пределом 1» по строке 1 \t 0,016 с – user2625363

+0

@ user2625363: Верно, пожалуйста, см. мой обновленный ответ. – wchiquito

+0

Спасибо, мне кажется, что работа сейчас, однако, я столкнулся с другой проблемой, как если бы поле получилось как ни одна строка, тогда это приведет к значению из предыдущего ненулевого результата, так или иначе, чтобы заставить его вернуть null? – user2625363

Смежные вопросы