我在任何地方都找不到这个答案,但是你能从 MySQL 中的另一个存储过程中调用一个存储过程吗?我想取回标识值并在父存储过程中使用它。我们不能再使用函数了!
问问题
97493 次
2 回答
80
CREATE PROCEDURE innerproc(OUT param1 INT)
BEGIN
insert into sometable;
SELECT LAST_INSERT_ID() into param1 ;
END
-----------------------------------
CREATE PROCEDURE outerproc()
BEGIN
CALL innerproc(@a);
// @a gives you the result of innerproc
SELECT @a INTO variableinouterproc FROM dual;
END
OUT
参数应该可以帮助您将值返回给调用过程。基于此,解决方案必须是这样的。
于 2012-06-12T16:34:56.203 回答
15
要调用另一个过程,请使用CALL:例如:Call SP1(parm1, parm2);
要获得身份,您是否尝试检查LAST_INSERT_ID();你会SELECT LAST_INSERT_ID()
在你的 SP 电话之后做一些事情。
这是一个完整的、经过测试的示例:
DELIMITER $$
CREATE TABLE animals (
id MEDIUMINT NOT NULL AUTO_INCREMENT,
name CHAR(30) NOT NULL,
PRIMARY KEY (id)
) $$
CREATE PROCEDURE sp1()
BEGIN
insert into animals (name) values ('bear');
END $$
CREATE PROCEDURE sp2()
BEGIN
call sp1;
select last_insert_id();
END $$
call sp2;
于 2012-06-12T16:31:39.990 回答