0

我有两张桌子。我想根据 table2 中的相同行索引更新 table1 中的一行。ID 不匹配,但表 2 中的 ID 与行索引匹配。表 2 中总会有更多数据,但我不在乎是否遗漏了额外的行。

我将如何在 mysql UPDATE 语句中实现这一点?

   table 1      ______________      table 2     _____________
   Row number  |  id  | value |    Row number | id  | value |
               |--------------|               |-----|-------|
        1      |  2   |   A   |        1      |  1  |   W   |
        2      |  4   |   B   |        2      |  2  |   X   |
        3      |  6   |   C   |        3      |  3  |   Y   |
                                       4      |  4  |   Z   |

  to:
    table 1      ______________    
    Row number |  id  | value |   
               |--------------|   
        1      |  2   |   W   |   
        2      |  4   |   X   |  
        3      |  6   |   Y   |    
4

1 回答 1

0

这行得通,但它并不漂亮。

set @c=0;
update t1
join (
    select tx.id,t2.value
    from t2
    join (
        select @c:=@c+1 as rownum, value, id
        from (
            select * from t1  order by id
        ) t3
    ) tx
    on t2.id=tx.rownum) tupdate
on t1.id = tupdate.id
set t1.value=tupdate.value;

它背后的基本点是使用变量来计算行数,然后使用它来连接。我最终使用了多个嵌套选择,因为要求是更新 t1 但只有在制作了一个包含行数的版本之后。

如果set重复,则需要在开始时阻止它过度计数。请参阅MySQL - Get row number on select以获得灵感。

于 2016-09-07T11:52:11.913 回答