MySql:设置一个带有列表的变量

Pau*_*zel 12 mysql sql

我一直在研究有关 MySQL 语句和类似问题的一些时间,但我似乎没有任何运气。

我可以创建一个变量来存储要在多个查询中使用的 1 列数据结果吗?这样做是否有效,或者我是否对 DB 与 PL 的不同感到困惑?

我在想类似下面的伪代码

SET list = Select ID from Sales;
Update items set aValue = X where salesID in list
delete SalesMessages where salesId in list
Run Code Online (Sandbox Code Playgroud)

我在存储过程中有大约 8 个更新要做,我可以为每个案例进行选择,而不是创建一个变量,但我觉得这不是最好的方法。有什么帮助吗?

Jpe*_*c07 20

MySQL 中的变量需要一个简单的值,通常是字符串、数字或布尔值。在这种情况下,您可以做的是通过 路由您的销售 ID GROUP_CONCAT(),这将返回所有销售 ID 的逗号分隔列表(有一些限制 - 如果您有很多销售 ID,您可能需要调整一些配置设置和根本无法过滤它们),然后执行 a FIND_IN_SET(),它检查逗号分隔列表中的值。像这样的东西适用于小集合:

SET @list = (SELECT GROUP_CONCAT(ID) FROM Sales);
UPDATE items SET aValue = X WHERE FIND_IN_SET(salesID, @list) > 0;
DELETE FROM SalesMessages WHERE FIND_IN_SET(salesId, @list) > 0;
Run Code Online (Sandbox Code Playgroud)

您还可以完全通过连接绕过变量创建,这会更快,并且可以绕过以下长度限制GROUP_CONCAT()

UPDATE items as i INNER JOIN Sales as s ON s.ID = i.salesID SET i.aValue = X;
DELETE sm FROM SalesMessages as sm INNER JOIN Sales as s ON s.ID = sm.salesID;
Run Code Online (Sandbox Code Playgroud)