gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-29 14:37:23 24 4
gpt4 key购买 nike

在我的存储过程中,我将列名称和值作为文本传递,使用 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

最佳答案

你的问题是这样的:

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;

关于mysql - 无法将变量分配给更新语句中的变量 MySQL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8753477/

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