2011-12-25 114 views
0

我收到以下错误。但是我没有在我的存储过程中输入count,所以为什么会出现这个错误?mysql存储过程列错误

CALL updateproposalStatus(1,5) Error Code: 1136. Column count doesn't match value count at row 1 

存储过程:

CREATE DEFINER=`root`@`localhost` PROCEDURE `updateProposalStatus`(IN decision INT, IN x INT) 
BEGIN 
DECLARE adv_id varchar(30); 
DECLARE std_id varchar(30); 
DECLARE topic varchar(255); 

select 
a.id INTO adv_id 
from 
rp_proposal p 
inner join rp_adviser a on p.rp_adviser_id = a.id 
where p.proposal_id=x; 

select 
s.id INTO std_id 
from 
rp_proposal p 
inner join rp_student s on p.rp_student_id = s.id 
where p.proposal_id=x; 

select 
p.title INTO topic 
from 
rp_proposal p 
where p.proposal_id=x; 

UPDATE rp_proposal_status 
SET state_rp_controller =decision 
WHERE rp_proposal_id = x; 

IF decision = 1 THEN 
INSERT INTO rp_indpstudy VALUES (topic,adv_id,std_id); 
END IF; 
END 

回答

1

它的列数(列数),它是在抱怨,不是关于一个叫count列。

最有可能的罪魁祸首是最后的insert声明 - 请确保它符合rp_indpstudy的模式。

+0

插入语句是罪魁祸首,因为我离开了主键ID字段。但是我把它设置为'AUTO INCREMENT',那么为什么它会给出一个错误。 – SupaOden 2011-12-25 13:32:19

+0

嗯,我通过INSERT INTO rp_indpstudy(name,rp_adviser_id,rp_student_id)VALUES(topic,adv_id,std_id)修复了错误;'在我没有指定列名之前 – SupaOden 2011-12-25 13:37:04