无法将变量分配给更新语句MySQL中的变量

时间:2012-01-06 04:45:33

标签: mysql prepared-statement

在我的存储过程中,我将列名和值作为文本传递,使用substring_index对它们进行子串,我试图像下面的代码一样分配它们。但MySQL提示我语法错误。

我该如何解决这个问题?

var1, var2 varchar(50);
set @var1 = substring_index(substring_index(substring_index(query,',',1),',',1),'=',1);
set @var2 = substring_index(substring_index(substring_index(query,',',1),',',1),'=',-1);

这里给出语法错误

update device
set @var1=@var2 
where dv_id=deviceId;

Error Code : 1064
You have an error in your SQL syntax; check the manual that corresponds to your MySQL  server version for the right syntax to use near '@var1=@var2
where dv_id=deviceId;
-- prepare stmt1 from @s;
-- execute stmt1 usi' at line 10

1 个答案:

答案 0 :(得分:1)

你的问题是:

set @var1 = @var2

不是UPDATE的值SET子句。 MySQL不会评估你的变量来获取它们包含的表达式。但是,您可以使用PREPAREEXECUTE动态构建和执行SQL。像这样:

set @var1   = substring_index(substring_index(substring_index(query,',',1),',',1),'=',1);
set @var2   = substring_index(substring_index(substring_index(query,',',1),',',1),'=',-1);
set @update = concat('update device set ', @var1, ' = ', @var2, ' where dv_id = deviceId');
prepare stmt from @update;
execute stmt;
deallocate prepare stmt;