在PHP同一事物里调用MYSQL的存储过程后再次执行另外的一个或多个命令(或者在同一事物里执行多个存储过程),如果使用mysqli的query方法获得结果,将获得一个错误:Commands out of sync; you can't run this command now sss  先给出代码:

存储过程:

CREATE PROCEDURE test1()
begin
        
drop table if exists tb1;
    
create table tb1
    (
        val 
int not null
    )engine 
= innoDB;
    
insert into tb1(val) values(1),(2),(3);
    
select * from tb1;
end

PHP代码:

Code1

执行上面的代码后就会出现上面的错误,消息说明MYSQL数据库认为是这一个错误的命令执行顺序。原因在于MYSQL的存储过程执行完成后除了返回实际结果集还会返回存储过程执行的转态

,而上面的代码仅处理了第一个结果集,第二个结果集并没有被释放掉。

When a stored procedure returns a resultset, MySQL returns at least two resultsets: first for the SELECT CALL inside the stored procedure. 2ndfor the call of the stored procedure itself

 (2nd usually is only an OK or ERR packet).

要解决这个问题,需要用mysqli的multi_query方法,遍历所有的结果集并释放掉掉。代码如下:

Code2

 

 

posted on 2009-04-29 16:22  空空儿  阅读(3111)  评论(2编辑  收藏  举报