合并或插入 db2 的忽略

Posted

技术标签:

【中文标题】合并或插入 db2 的忽略【英文标题】:merge into or insert ignore for db2 【发布时间】:2019-10-07 12:40:44 【问题描述】:

我觉得这应该相当简单,但我在找出最佳方法时遇到了问题

我在这个 subitem_to_item_status 表中有许多具有状态的子项,但我需要为所有尚不存在的子项插入一条记录。我不需要更新里面的内容,我只是想复制一个“插入/忽略”

子项的样本数据

ITEM_SUBITEMT

item_subitem_id   |   creator_identifier
-----------------------------------------
12                      12345
13                      12345
14                      12345
15                      12345
16                      12345
17                      12345
18                      12345
19                      12345
20                      12345
21                      12345
22                      12345

SUBITEM_TO_ITEM_STATUS

SUBITEM_ID   |   ITEM_STATUS_ID   |   CREATED_BY_IDENTIFIER   
------------------------------------------------------------
12                  1                   12345
15                  1                   12345
16                  1                   12345
20                  1                   12345

所以有了这些数据,我只需要插入第一个表中没有 id 12、15、16 或 20 的记录

    MERGE INTO schema.SUBITEM_TO_ITEM_STATUS (SUBITEM_ID,ITEM_STATUS_ID, CREATED_BY_IDENTIFIER,ROWCHANGE,CREATED_AT) AS T
    USING( (SELECT ITEM_SUBITEM_ID, 1, CREATOR_IDENTIFIER, NOW(),NOW() FROM schema.ITEM_SUBITEMT) AS S
    ON S.ITEM_SUBITEM_ID = T.SUBITEM_ID
    WHEN NOT MATCHED THEN INSERT;

【问题讨论】:

【参考方案1】:

MERGE 声明错误。 试试这个:

MERGE INTO schema.SUBITEM_TO_ITEM_STATUS T
USING (SELECT ITEM_SUBITEM_ID, 1 AS ITEM_STATUS_ID, creator_identifier FROM schema.ITEM_SUBITEMT) S ON S.ITEM_SUBITEM_ID = T.SUBITEM_ID
WHEN NOT MATCHED THEN 
INSERT (SUBITEM_ID, ITEM_STATUS_ID, CREATED_BY_IDENTIFIER) 
VALUES (S.item_subitem_id, S.ITEM_STATUS_ID, S.creator_identifier);

【讨论】:

【参考方案2】:

为什么不使用insert

insert into SUBITEM_TO_ITEM_STATUS (SUBITEM_ID, ITEM_STATUS_ID, CREATED_BY_IDENTIFIER)
   select item_subitem_id, 1, creator_identifier
   from ITEM_SUBITEMT
   where item_subitem_id not in (12, 15, 16, 20);

如果你的意思是你不想在表中重复,你可以试试:

insert into SUBITEM_TO_ITEM_STATUS (SUBITEM_ID, ITEM_STATUS_ID, CREATED_BY_IDENTIFIER)
   select item_subitem_id, 1, creator_identifier
   from ITEM_SUBITEMT s
   where not exists (select 1
                     from SUBITEM_TO_ITEM_STATUS tis
                     where tis.item_subitem_id = s.item_subitem_id
                    );

【讨论】:

以上是关于合并或插入 db2 的忽略的主要内容,如果未能解决你的问题,请参考以下文章

Upsert(合并)用于更新记录(如果存在),否则插入

db2 merge update

将 JSON 文本插入 DB2 表

DB2 选择设置参数,然后用参数值插入

DB2 根据 php 脚本中的绑定参数选择和插入

Android 批量插入或忽略 JSONArray