MERGE - Amazon Redshift

Terjemahan disediakan oleh mesin penerjemah. Jika konten terjemahan yang diberikan bertentangan dengan versi bahasa Inggris aslinya, utamakan versi bahasa Inggris.

MERGE

Secara kondisional menggabungkan baris dari tabel sumber ke dalam tabel target. Secara tradisional, ini hanya dapat dicapai dengan menggunakan beberapa pernyataan insert, update atau delete secara terpisah. Untuk informasi selengkapnya tentang operasi yang menggabungkan memungkinkan Anda menggabungkan, lihat UPDATE, DELETE, dan INSERT.

Sintaks

MERGE INTO target_table USING source_table [ [ AS ] alias ] ON match_condition [ WHEN MATCHED THEN { UPDATE SET col_name = { expr } [,...] | DELETE } WHEN NOT MATCHED THEN INSERT [ ( col_name [,...] ) ] VALUES ( { expr } [, ...] ) | REMOVE DUPLICATES ]

Parameter

target_table

Tabel sementara atau permanen tempat pernyataan MERGE digabungkan.

source_table

Tabel sementara atau permanen yang memasok baris untuk digabungkan menjadi target_table. source_table juga bisa menjadi tabel Spectrum. source_table tidak bisa berupa tampilan atau subquery.

alias

Nama alternatif sementara untuk source_table.

Parameter ini bersifat opsional. Alias sebelumnya dengan AS juga opsional.

match_condition

Menentukan predikat yang sama antara kolom tabel sumber dan kolom tabel target yang digunakan untuk menentukan apakah baris di source_table dapat dicocokkan dengan baris di target_table. Jika kondisi terpenuhi, MERGE menjalankan matched_clause untuk baris itu. Jika tidak, MERGE menjalankan not_matched_clause untuk baris itu.

SAAT DICOCOKKAN

Menentukan tindakan yang akan dijalankan ketika kondisi kecocokan antara baris sumber dan baris target mengevaluasi ke True. Anda dapat menentukan tindakan UPDATE atau tindakan DELETE.

UPDATE

Memperbarui baris yang cocok di target_table. Hanya nilai dalam col_name yang Anda tentukan yang diperbarui.

DELETE

Menghapus baris yang cocok di target_table.

BILA TIDAK COCOK

Menentukan tindakan yang akan dijalankan ketika kondisi kecocokan dievaluasi ke False atau Unknown. Anda hanya dapat menentukan tindakan insert insert untuk klausa ini.

INSERT

Menyisipkan satu baris ke target_table. Col_name target dapat dicantumkan dalam urutan apa pun. Jika Anda tidak memberikan nilai col_name, urutan default adalah semua kolom tabel dalam urutan yang dideklarasikan.

col_name

Satu atau beberapa nama kolom yang ingin Anda ubah. Jangan sertakan nama tabel saat menentukan kolom target.

expr

Ekspresi mendefinisikan nilai baru untuk col_name.

HAPUS DUPLIKAT

Menentukan bahwa perintah MERGE berjalan dalam mode disederhanakan. Mode yang disederhanakan memiliki persyaratan sebagai berikut:

  • target_table dan source_table harus memiliki jumlah kolom yang sama dan jenis kolom yang kompatibel.

  • Hilangkan klausa WHEN dan klausa UPDATE dan INSERT dari perintah MERGE Anda.

  • Gunakan klausa REMOVE DUPLICATES dalam perintah MERGE Anda.

Dalam mode yang disederhanakan, MERGE melakukan hal berikut:

  • Baris di target_table yang memiliki kecocokan di source_table diperbarui agar sesuai dengan nilai di source_table.

  • Baris di source_table yang tidak memiliki kecocokan di target_table disisipkan ke target_table.

  • Ketika beberapa baris di target_table cocok dengan baris yang sama di source_table, baris duplikat akan dihapus. Amazon Redshift menyimpan satu baris dan memperbaruinya. Baris duplikat yang tidak cocok dengan baris di source_table tetap tidak berubah.

Menggunakan REMOVE DUPLICATES memberikan kinerja yang lebih baik daripada menggunakan WHEN MATCHED dan WHEN NOT MATCHED. Sebaiknya gunakan REMOVE DUPLICATES jika target_table dan source_table kompatibel dan Anda tidak perlu mempertahankan baris duplikat di target_table.

Catatan penggunaan

  • Untuk menjalankan pernyataan MERGE, Anda harus menjadi pemilik source_table dan target_table, atau memiliki izin SELECT untuk tabel tersebut. Selain itu, Anda harus memiliki izin UPDATE, DELETE, dan INSERT untuk target_table tergantung pada operasi yang disertakan dalam pernyataan MERGE Anda.

  • target_table tidak bisa berupa tabel sistem, tabel katalog, atau tabel eksternal.

  • source_table dan target_table tidak bisa menjadi tabel yang sama.

  • Anda tidak dapat menggunakan klausa WITH dalam pernyataan MERGE.

  • Baris di target_table tidak dapat mencocokkan beberapa baris di source_table.

    Pertimbangkan contoh berikut:

    CREATE TABLE target (id INT, name CHAR(10)); CREATE TABLE source (id INT, name CHAR(10)); INSERT INTO target VALUES (1, 'Bob'), (2, 'John'); INSERT INTO source VALUES (1, 'Tony'), (1, 'Alice'), (3, 'Bill'); MERGE INTO target USING source ON target.id = source.id WHEN MATCHED THEN UPDATE SET id = source.id, name = source.name WHEN NOT MATCHED THEN INSERT VALUES (source.id, source.name); ERROR: Found multiple matches to update the same tuple. MERGE INTO target USING source ON target.id = source.id WHEN MATCHED THEN DELETE WHEN NOT MATCHED THEN INSERT VALUES (source.id, source.name); ERROR: Found multiple matches to update the same tuple.

    Dalam kedua pernyataan MERGE, operasi gagal karena ada beberapa baris dalam source tabel dengan nilai ID. 1

  • match_condition dan expr tidak dapat mereferensikan sebagian kolom tipe SUPER. Misalnya, jika objek tipe SUPER Anda adalah array atau struktur, Anda tidak dapat menggunakan elemen individual dari kolom tersebut untuk match_condition atau expr, tetapi Anda dapat menggunakan seluruh kolom.

    Pertimbangkan contoh berikut:

    CREATE TABLE IF NOT EXISTS target (key INT, value SUPER); CREATE TABLE IF NOT EXISTS source (key INT, value SUPER); INSERT INTO target VALUES (1, JSON_PARSE('{"key": 88}')); INSERT INTO source VALUES (1, ARRAY(1, 'John')), (2, ARRAY(2, 'Bill')); MERGE INTO target USING source ON target.key = source.key WHEN matched THEN UPDATE SET value = source.value[0] WHEN NOT matched THEN INSERT VALUES (source.key, source.value[0]); ERROR: Partial reference of SUPER column is not supported in MERGE statement.

    Untuk informasi selengkapnya tentang tipe SUPER, lihat tipe SUPER.

  • Jika source_table berukuran besar, mendefinisikan kolom gabungan dari target_table dan source_table sebagai kunci distribusi dapat meningkatkan kinerja.

  • Untuk menggunakan klausa HAPUS DUPLIKAT, Anda memerlukan izin SELECT, INSERT, dan DELETE untuk target_table.

Contoh-contoh

Contoh berikut membuat dua tabel, lalu menjalankan operasi MERGE pada mereka, memperbarui baris yang cocok dalam tabel target dan menyisipkan baris yang tidak cocok. Kemudian menyisipkan nilai lain ke dalam tabel sumber dan menjalankan operasi MERGE lain, kali ini menghapus baris yang cocok dan memasukkan baris baru dari tabel sumber.

Pertama buat dan isi tabel sumber dan target.

CREATE TABLE target (id INT, name CHAR(10)); CREATE TABLE source (id INT, name CHAR(10)); INSERT INTO target VALUES (101, 'Bob'), (102, 'John'), (103, 'Susan'); INSERT INTO source VALUES (102, 'Tony'), (103, 'Alice'), (104, 'Bill'); SELECT * FROM target; id | name -----+------------ 101 | Bob 102 | John 103 | Susan (3 rows) SELECT * FROM source; id | name -----+------------ 102 | Tony 103 | Alice 104 | Bill (3 rows)

Selanjutnya, gabungkan tabel sumber ke dalam tabel target, perbarui tabel target dengan baris yang cocok dan masukkan baris dari tabel sumber yang tidak cocok.

MERGE INTO target USING source ON target.id = source.id WHEN MATCHED THEN UPDATE SET id = source.id, name = source.name WHEN NOT MATCHED THEN INSERT VALUES (source.id, source.name); SELECT * FROM target; id | name -----+------------ 101 | Bob 102 | Tony 103 | Alice 104 | Bill (4 rows)

Perhatikan bahwa baris dengan nilai id 102 dan 103 diperbarui agar sesuai dengan nilai nama dari tabel target. Juga, baris baru dengan nilai id 104 dan nilai nama Bill dimasukkan ke dalam tabel target.

Selanjutnya, masukkan baris baru ke dalam tabel sumber.

INSERT INTO source VALUES (105, 'David'); SELECT * FROM source; id | name -----+------------ 102 | Tony 103 | Alice 104 | Bill 105 | David (4 rows)

Terakhir, jalankan operasi gabungan menghapus baris yang cocok di tabel target, dan menyisipkan baris yang tidak cocok.

MERGE INTO target USING source ON target.id = source.id WHEN MATCHED THEN DELETE WHEN NOT MATCHED THEN INSERT VALUES (source.id, source.name); SELECT * FROM target; id | name -----+------------ 101 | Bob 105 | David (2 rows)

Baris dengan nilai id 102, 103, dan 104 dihapus dari tabel target, dan baris baru dengan nilai id 105 dan nilai nama David dimasukkan ke dalam tabel target.

Contoh berikut menunjukkan perintah MERGE menggunakan klausa REMOVE DUPLICATES.

CREATE TABLE target (id INT, name CHAR(10)); CREATE TABLE source (id INT, name CHAR(10)); INSERT INTO target VALUES (30, 'Tony'), (11, 'Alice'), (23, 'Bill'); INSERT INTO source VALUES (23, 'David'), (22, 'Clarence'); MERGE INTO target USING source ON target.id = source.id REMOVE DUPLICATES; SELECT * FROM target; id | name ---+------------ 30 | Tony 11 | Alice 23 | David 22 | Clarence (4 rows)

Contoh berikut menunjukkan perintah MERGE menggunakan klausa REMOVE DUPLICATES, menghapus baris duplikat dari target_table jika mereka memiliki baris yang cocok di source_table.

CREATE TABLE target (id INT, name CHAR(10)); CREATE TABLE source (id INT, name CHAR(10)); INSERT INTO target VALUES (30, 'Tony'), (30, 'Daisy'), (11, 'Alice'), (23, 'Bill'), (23, 'Nikki'); INSERT INTO source VALUES (23, 'David'), (22, 'Clarence'); MERGE INTO target USING source ON target.id = source.id REMOVE DUPLICATES; SELECT * FROM target; id | name ---+------------ 30 | Tony 30 | Daisy 11 | Alice 23 | David 22 | Clarence (5 rows)

Setelah MERGE berjalan, hanya ada satu baris dengan nilai ID 23 di target_table. Karena tidak ada baris di source_table dengan nilai ID 30, dua baris duplikat dengan nilai ID 30 tetap berada di target_table.

Lihat juga

INSERT, UPDATE, DELETE