![](https://img2023.cnblogs.com/blog/3076680/202307/3076680-20230719144557396-616589792.png) # 1. 結果集分頁 ## 1.1. 只有做過了排序,才有可能準確地從結果集中返回指定區間的記錄 ## 1.2. ...
使用 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;