我试图用另一个表中的值+一点算术来更新一个表列。我不是专家,但读了几个问题,似乎我不得不使用公共列上的JOIN从两个表中选择数据。

UPDATE Farming SET Farming.GoldLabor = Farming.GoldPerUnit / (DataTable.LaborYieldA +
DataTable.LaborYieldB)
FROM Farming f INNER JOIN DataTable d ON f.name = d.name;

错误是:
#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 'FROM Farming f INNER JOIN
DataTable d ON f.name = d.name' at line 1

我使用的代码来自这里回答的其他几个问题。
https://stackoverflow.com/a/707383
https://stackoverflow.com/a/1746161
我正在使用1&1宿主中的mySQL,并且尝试使用JOIN和INNER JOIN。
谢谢你的时间。

最佳答案

MySQL支持包含连接的多表更新语法,但不像您现在所做的那样。您显示的语法可能适用于Microsoft SQL Server,但不适用于MySQL。
这应该有效:

UPDATE Farming f INNER JOIN DataTable d ON f.name = d.name
SET f.GoldLabor = f.GoldPerUnit / (d.LaborYieldA + d.LaborYieldB);

关于mysql - 此UPDATE查询有什么问题?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/26005400/

10-15 21:19