UPDATE语法与ORDER BY,LIMIT和多个表(UPDATE Syntax with OR

2019-06-24 08:27发布

学习SQL,对不起,如果这是最基本的。 试图找出工作UPDATE以下pseudoish代码的解决方案:

UPDATE tableA 
SET tableA.col1 = '$var'
WHERE tableA.user_id = tableB.id
AND tableB.username = '$varName'
ORDER BY tableA.datetime DESC LIMIT 1

以上是更像SELECT语法,但我基本上是试图更新表A的最新行 ,其中(由$ varname的代表)在tableB.username发现了一个用户名被链接到它的ID号在tableB.id在一列中的值,它存在在tableA.user_id的ID。

我们希望,这是有道理的。 我猜某种JOIN是必要的,但子查询似乎麻烦的UPDATE 。 我明白ORDER BYLIMIT都关闭时,多个表涉及UPDATE限制......但我需要的功能。 有没有解决的办法?

有点困惑,在此先感谢。

Answer 1:

解决的办法是巢ORDER BY和LIMIT FROM子句中作为一个连接的一部分。 这使你可以找到确切的行进行更新(ta.id),然后再提交更新。

UPDATE tableA AS target
    INNER JOIN (
      SELECT ta.id
      FROM tableA AS ta
        INNER JOIN tableB AS tb ON tb.id = ta.user_id
        WHERE tb.username = '$varName'
        ORDER BY ta.datetime DESC
        LIMIT 1) AS source ON source.id = target.id
    SET col1 = '$var';

帽尖到巴伦·施瓦茨,又名Xaprb,对这个确切主题的优秀帖子: http://www.xaprb.com/blog/2006/08/10/how-to-use-order-by-and-limit-上的多表更新-在MySQL的/



Answer 2:

您可以使用下面的查询语法:

update work_to_do as target
   inner join (
      select w. client, work_unit
      from work_to_do as w
         inner join eligible_client as e on e.client = w.client
      where processor = 0
      order by priority desc
      limit 10
   ) as source on source.client = target.client
      and source.work_unit = target.work_unit
   set processor = @process_id;

这完美的作品。



文章来源: UPDATE Syntax with ORDER BY, LIMIT and Multiple Tables