記錄Oracle數據庫高效批量更新操作 MERGE INTO

2024年2月6日 22点热度 0人点赞

使用 UPDATE 批量更新大量的數據,會出現效率低下,有時候甚至卡死的情況,後面通過使用 MERGE INTO 代替 UPDATE 執行批量更新,會提升執行效率。

原理:因為 UPDATE 關聯子查詢寫法,是選到一條做一次子查詢,這種寫法得更新少,走好的索引才行,MERGE 寫法是執行完 ON 後一次性更新,效率會好點。

語法:

MERGE INTO table_name alias1
USING (table|view|sub_query) alias2
ON (join condition)
WHEN MATCHED AND 限制條件 THEN  --目標表存在,源表存在
UPDATE table_name
SET col1 = col_val1,
col2 = col2_val
WHEN NOT MATCHED AND 限制條件 THEN  --目標表存在,源表不存在
INSERT (column_list) VALUES (column_values)
WHEN NOT MATCHED AND 限制條件 THEN SOURCE THEN --目標表存在,源表不存在
DELETE--刪除目標表數據;接操作語句自定義
OUTPUT $ACTION AS [ACTION],
Insterted.id as 插入的id,
Insterted.[DESC] as 插入的DESC,
deleted.id as 刪除的id,
deleted.[DESC] as 刪除的DESC

簡單示例:

MERGE INTO TEST_MERGE_INTO T1
USING TEST_MERGE_INTO_DETAIL T2
ON (T1.ID = T2.ID)
WHEN MATCHED THEN
  UPDATE SET ITEM_NAME = T2.ITEM_NAME
WHEN NOT MATCHED THEN
  INSERT (ID, ITEM_NO, ITEM_NAME) VALUES (1, '031', 'api');
COMMIT;