Ini biasanya disebabkan oleh duplikat dalam kueri yang ditentukan dalam klausa USING. Ini mungkin berarti bahwa TABLE_A adalah tabel induk dan ROWID yang sama dikembalikan beberapa kali.
Anda dapat dengan cepat menyelesaikan masalah dengan menggunakan DISTINCT dalam kueri Anda (sebenarnya, jika 'Y' adalah nilai konstan, Anda bahkan tidak perlu memasukkannya ke dalam kueri).
Dengan asumsi kueri Anda benar (tidak tahu tabel Anda), Anda dapat melakukan sesuatu seperti ini:
MERGE INTO table_1 a
USING
(SELECT distinct ta.ROWID row_id
FROM table_1 a ,table_2 b ,table_3 c
WHERE a.mbr = c.mbr
AND b.head = c.head
AND b.type_of_action <> '6') src
ON ( a.ROWID = src.row_id )
WHEN MATCHED THEN UPDATE SET in_correct = 'Y';