gpt4 book ai didi

mysql - 存储过程输出变量

转载 作者:行者123 更新时间:2023-11-29 23:03:25 33 4
gpt4 key购买 nike

我正在尝试运行一个过程,该过程采用参数“表”进行查询,并将结果作为输出参数。但是,它显示为未声明的变量:结果

我已经仔细检查过没有拼写错误,但仍然不知道它是怎么发生的。请有人提供一些帮助或指导

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

最佳答案

尝试:

...
-- 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

关于mysql - 存储过程输出变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28393268/

33 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com