高级DBA教你达梦8国产数据库MergeInto批量插入并忽略主键重复报错特殊用法
-- 批量插入数据到目标表,忽略主键冲突,即不更新主键相同的记录
MERGE INTO 目标表 T
USING (SELECT /*+ use_hash(A) */ 主键字段, 其他字段 FROM 源表 A) S
ON (T.主键字段 = S.主键字段)
WHEN NOT MATCHED THEN
INSERT (T.主键字段, T.其他字段)
VALUES (S.主键字段, S.其他字段);
-- 示例代码
MERGE INTO target_table T
USING (SELECT /*+ use_hash(a) */ pk_column, other_columns FROM source_table a) S
ON (T.pk_column = S.pk_column)
WHEN NOT MATCHED THEN
INSERT (T.pk_column, T.other_columns)
VALUES (S.pk_column, S.other_columns);
这段代码使用了达梦数据库特有的MERGE INTO语法,用于在一条语句中同时进行插入和更新操作。它会尝试将源表中的每一行与目标表进行匹配,如果不存在匹配的行,则执行插入操作;如果存在匹配的行,且这里的匹配条件是基于主键,则不执行任何操作。这样可以避免因主键冲突而导致的错误,并确保目标表中的数据是唯一的。
评论已关闭