这个UPDATE查询有什么问题?

时间:2014-09-23 21:59:58

标签: mysql join sql-update

我正在尝试使用另一个表中的值+一个小算术来更新表列。我不是专家,但是阅读几个问题似乎我必须在COMMON列上使用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 Hosting中的mySQL,我尝试使用JOIN& INNER JOIN。

感谢您的时间。

2 个答案:

答案 0 :(得分:2)

MySQL支持带有连接的多表UPDATE语法,但不像你正在做的那样。您显示的语法可能适用于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);

答案 1 :(得分:0)

试试这个:

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

SQLFiddle