Oracle Merge vs Выберите "Вставить" или "Обновить"
Что быстрее?
оператор слияния
MERGE INTO table_name
USING dual
ON (row_id = 'some_id')
WHEN MATCHED THEN
UPDATE SET col_name = 'some_val'
WHEN NOT MATCHED THEN
INSERT (row_id, col_name)
VALUES ('some_id', 'some_val')
или
запрашивает оператор select, а затем использует инструкцию update или insert.
SELECT * FROM table_name where row_id = 'some_id'
если rowCount == 0
INSERT INTO table_name (row_id,col_name) VALUES ('some_id','some_val')
еще
UPDATE table_name SET col_name='some_val' WHERE row_id='some_id'
Ответы
Ответ 1
Эмпирическое правило: если вы можете сделать это в одном SQL, оно будет работать лучше, чем в нескольких операциях SQL.
Я бы пошел с MERGE, если он выполнит эту работу.
Также - другое предложение: вы можете избежать повторения данных в своем заявлении, например:
MERGE INTO table
USING (SELECT 'some_id' AS newid,
'some_val' AS newval
FROM dual)
ON (rowid = newid)
WHEN MATCHED THEN
UPDATE SET colname = newval
WHEN NOT MATCHED THEN
INSERT (rowid, colname)
VALUES (newid, newval)
Ответ 2
Позаботьтесь о слиянии. Он может потреблять большую часть вашей области TEMP
, используя HASH JOIN
. Протестируйте его с помощью подсказки FIRST_ROWS
или используйте UPDATE
для просмотра соединения плюс INSERT
с помощью NOT EXISTS
.