SQL查询语法错误,使用INNER JOIN

时间:2018-07-09 06:51:06

标签: mysql sql syntax syntax-error inner-join

我的问题应该很容易解决,但是我找不到数据库接口向我抛出的语法错误。以下代码用于更新timetrackingtool中现有用户的密码。

我检查了所有的表和字段名称,它们都是正确的。

SQL查询代码:

$query = ('UPDATE tblMitarbeiterUUID SET tblMitarbeiterUUID.dtPassword="' . $pwd . '" '.
          'INNER JOIN arbeiter '.
          'ON tblMitarbeiterUUID.idMitarbeiterUUID=arbeiter.fidMitarbeiterUUID ' .
          'WHERE arbeiter.id=' . $userID)

此查询的回声:

UPDATE tblMitarbeiterUUID SET tblMitarbeiterUUID.dtPassword="7687225fde7aad38f4c005ad4b5cdd5a" INNER JOIN arbeiter ON tblMitarbeiterUUID.idMitarbeiterUUID=arbeiter.fidMitarbeiterUUID WHERE arbeiter.id=1

尝试直接在数据库上运行查询时遇到错误:

  

SQL错误(1064):您的SQL语法有错误;在第1行的' FROM tblMitarbeiterUUID INNER JOIN arbeiter ON tblMitarbeiterUUID.ifMitarbeiterUUID = arbeiter.fidMitar ... '附近检查与您的MariaDB服务器版本相对应的手册以使用正确的语法。

在我的研究中,我看到一些人在FROM语句中使用UPDATE并使用INNER JOIN。我使用FROM进行了尝试,但遇到了与上述相同的错误。

非常感谢您的帮助。最好的问候,卢卡。

正确的语法(我得到正确答案后进行了编辑):

'UPDATE tblMitarbeiterUUID x '.
'JOIN arbeiter y ON x.idMitarbeiterUUID = y.fidMitarbeiterUUID ' .
'SET x.dtPassword="' . $pwd . '" ' .
'WHERE y.id=' . $userID

1 个答案:

答案 0 :(得分:3)

这是有效的语法:

UPDATE tblMitarbeiterUUID x

JOIN arbeiter y
ON x.idMitarbeiterUUID = y.fidMitarbeiterUUID 

SET x.dtPassword="A"  

WHERE y.id=1