【问题标题】:Insert into TableA from TableB where FieldX Value does not exist yet从 TableB 插入到 TableA 中,其中 FieldX 值尚不存在
【发布时间】:2014-04-29 23:02:55
【问题描述】:

我能够从表 B 向表 A 中进行基本插入操作,但是我希望仅当 FieldX 定义的 TableA 中存在的记录尚不存在于 TableB 中时才这样做。

【问题讨论】:

  • 我们应该用这些词做什么?如果记录存在于tableA中,您想插入tableA吗?向我们展示一些代码和表结构。

标签: mysql insert


【解决方案1】:

为了获得更好的性能,请使用以下查询:

insert into tableA (col1, col2, col3)
select col1, col2, col3
from tableB b
left join TableA a on a.FieldX=b.FieldX
where a.FieldX is null

【讨论】:

    【解决方案2】:

    假设您需要在基于FieldX的TableB中插入存在于TableA中的记录,您可以尝试类似,

    INSERT INTO TableA (col1, col2, col3)
    SELECT col1, col2, col3
    FROM   TableB
    WHERE  FieldX not in (select FieldX from TableA)
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2020-01-27
      • 2014-11-24
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2021-03-01
      相关资源
      最近更新 更多