我正在尝试在存储过程中使用准备好的语句。我在初始SET @idToUpdateQuery
中遇到语法错误。我已经知道没有使用concat
进行变量分配的:=
可以正常工作,因为它已在其他地方使用并按预期工作。本质上,我只需要能够将准备好的SELECT语句的结果放入变量@resultId
中。有问题的代码如下:
SET @distinctTableXIds = (SELECT COUNT(*) FROM tempTableX);
SET @i = 0;
WHILE @i < @distinctTableXIds DO
/*concat IS NEEDED HERE TO PASS USER DEFINED @i*/
SET @idToUpdateQuery = concat('SELECT @result := MAX(id)
FROM tableY
WHERE tableZId = (SELECT id FROM tempTableX ORDER BY id LIMIT ',@i,',1)');
PREPARE @IdToUpdateStmt FROM @IdToUpdateQuery;
EXECUTE @IdToUpdateStmt;
SET @resultId = SELECT @result;
UPDATE tableY
SET someBoolean = 1
WHERE id = @resultId;
SET @i = @i + 1;
END WHILE;