使用ORDER BY,LIMIT和Multiple Tables更新语法

时间:2012-05-11 02:07:33

标签: mysql syntax sql-update

学习SQL,对不起,如果这是初步的。试图为以下伪代码找出一个有效的UPDATE解决方案:

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

以上内容更像是SELECT语法,但我基本上尝试更新tableA的最新行中的单个列值,其中在tableB.username中找到用户名(由$ varName)链接到tableB.id中的ID号,该表号作为tableA.user_id中的id存在。

希望这是有道理的。我猜某种JOIN是必要的,但子查询对于UPDATE来说似乎很麻烦。在UPDATE中涉及多个表时,我理解ORDER BYLIMIT是不受限制的......但我需要这个功能。有办法解决这个问题吗?

有点困惑,提前谢谢。

2 个答案:

答案 0 :(得分:15)

解决方案是将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';

向Baron Schwartz,a.k.a。Xaprb提示,以获得关于这个话题的精彩帖子: http://www.xaprb.com/blog/2006/08/10/how-to-use-order-by-and-limit-on-multi-table-updates-in-mysql/

答案 1 :(得分:0)

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

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;

这很有效。