根据MySQL 8.0反对意见备注,启动MySQL 9.0将不再推荐使用DECLARE (例如DECLARE studentID INT)定义用户变量:
对在
SET以外的语句中设置用户变量的支持在MySQL 8.0.13中被取消。此功能将在MySQL 9.0中删除。
如今,MySQL 8.0.25已经提出了一个警告:
1287在表达式中设置用户变量是不推荐的,并将在以后的发行版中删除。考虑一下替代方案:
SET variable=expression, ...__或SELECT expression(s) INTO variables(s)__。
因此,我想了解如何将DECLARE正确地替换为SET。假设,我声明了以下变量:
DECLARE cursor_studentID INT;
DECLARE done INT DEFAULT FALSE;
DECLARE cursor_i CURSOR FOR SELECT courseID FROM tblCoursesToCopy;
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;现在,我想使这些声明MySQL 9.0兼容。在DECLARE cursor_studentID INT;的情况下,所有事情都比较明显:
DECLARE cursor_studentID INT; → SET @cursor_studentID;真正的障碍是最后一个案例:
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = TRUE;如何用SET-based方法替换它?
发布于 2021-06-02 21:10:59
反对警告不明确,很容易被误解。
不建议使用DECLARE语法。我认为发布说明的作者并不认为是一种“设置”变量的方法。诚然,它确实通过使用可选的DEFAULT子句为声明的变量设置了一个初始值。但我仍然把它解释为一种不被视为不受欢迎的声明。
所反对的是在如下表达式中将变量设置为“副作用”:
SELECT @row := @row+1, ...这种技术是MySQL在8.0之前发布的版本中缺少窗口函数的常见解决方法。但这是一种非标准的语法,而且通常容易出错,使用起来也很棘手。既然MySQL支持标准的SQL函数和通用表表达式,那么您就可以编写查询,就像在其他流行的SQL实现中编写查询一样。上面的例子是:
SELECT ROW_NUMBER() OVER (), ...:=赋值的另一种用途是将表达式从查询的选择列表保存到用户定义的变量中。MySQL为这种用法提供了语法。在8.0版之前,这已经被支持了很长一段时间。
我们还没有听到任何关于更改DECLARE语法的声明。这不需要改变。
关于你的评论:
您可以使用以下任何一种表单来代替SELECT @myVar := somevalue ...:
SELECT someValue INTO @myVar ...
SET @myVar = (SELECT someValue FROM ...);注后一种形式不允许每次查询设置多个变量。前者允许您设置如下多个变量:
SELECT someValue, otherValue INTO @myVar1, @myVal2 ...阅读上面链接到的关于SELECT ... INTO的文档。
https://stackoverflow.com/questions/67812419
复制相似问题