如何加入两个表并更新一列?

发布于 2025-01-28 20:16:34 字数 539 浏览 2 评论 0原文

我有两个表,如下所

   TableA          TableB   
    ID1 ID2         ID1 ID3
    1   X           1   X
    2   NULL        2   A
    3   (NULL)      3   B
    4   (NULL)      4   C
    5   (NULL)      5   D

预期的结果:

    TableA  
   ID1  ID2
   1    X
   2    A
   3    B
   4    C
   5    D

我的查询:

     UPDATE TableA a LEFT JOIN TableB b  ON a.ID1 =  b.ID1
     SET a.ID2  = b.ID3 
     WHERE   a.ID2 is NULL OR  a.ID2 != b.ID3

但是上面的查询是循环的。感谢您提前的帮助。

I have two tables as below

   TableA          TableB   
    ID1 ID2         ID1 ID3
    1   X           1   X
    2   NULL        2   A
    3   (NULL)      3   B
    4   (NULL)      4   C
    5   (NULL)      5   D

Expected Result:

    TableA  
   ID1  ID2
   1    X
   2    A
   3    B
   4    C
   5    D

My query:

     UPDATE TableA a LEFT JOIN TableB b  ON a.ID1 =  b.ID1
     SET a.ID2  = b.ID3 
     WHERE   a.ID2 is NULL OR  a.ID2 != b.ID3

But the above query is going in a loop. Thanks for your help in advance.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

渡你暖光 2025-02-04 20:16:34

如果您的桌子看起来完全像您的问题中的表格,那么您无需加入桌子,您的表格是右侧的桌子。

select * 
from table b;

If your tables look exactly like the ones you have in your question then you have no need to join the tables, your resulting table is the table on the right.

select * 
from table b;
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文