首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从另一个表更新,但在计算列上联接

从另一个表更新,但在计算列上联接
EN

Stack Overflow用户
提问于 2021-01-12 05:28:33
回答 1查看 14关注 0票数 0

表A有三列: IP地址(Varchar)、实验室ID(int)和源地址(int)。

表B有两列: ID(int)和labName(varchar)

labName表B由IP地址A中的第一个八位字节组成。例如,如果IP是192.168.5.18,那么将有一个实验室名称'lab 192‘。我需要做的是用表B中的匹配ID更新表A的labID列。

我已经完成了从IP构建实验室名称的解析:

我不确定该如何做的是基于该计算字段的更新。下面的代码不能工作,但我希望它能解释我正在尝试做的事情:

代码语言:javascript
复制
UPDATE tableA
SET labID = (
    SELECT labName
    FROM tableB
    WHERE labName = concat(‘lab ‘, substring_index(ip, “.”, 1)
)
WHERE origin = 3
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-01-12 05:36:25

MySQL将允许您使用UPDATE syntaxtable_reference的连接调用join的ON子句中的函数(或任何表达式

代码语言:javascript
复制
UPDATE
  tableA
  -- Join on the IP substring expression
  INNER JOIN tableB ON tableB.labName = CONCAT('lab ', substring_index(tableA.ip, '.', 1))
-- Set labID to tableB ID
SET tableA.labID = tableB.ID
WHERE origin = 3
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65674780

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档