Birleştirme (SQL) - Merge (SQL)

Bir ilişkisel veritabanı yönetim sistemi kullanır SQL BİRLEŞTİRMEK (olarak da adlandırılır yükseltmek) ifadeleri INSERT yeni kayıtlar veya GÜNCELLEME olup olmamasına bağlı olarak mevcut kayıtlar şart maçlar. Resmen tanıtıldı SQL: 2003 standart ve genişletilmiş SQL: 2008 standart.

Kullanım

BİRLEŞTİRMEKINTOTablo ismiKULLANIMItable_referenceAÇIK(şart)NE ZAMANEŞLEŞTİRİLDİSONRAGÜNCELLEMEAYARLAMAKsütun1=değer1[, sütun2 = değer2 ...]NE ZAMANDEĞİLEŞLEŞTİRİLDİSONRAINSERT(sütun1[, sütun2 ...])DEĞERLER(değer1[, değer2 ...]);

Bir doğru katıl Hedef (INTO tablosu) ve Kaynak (KULLANILAN tablo / görünüm / alt sorgu) üzerinde kullanılır - burada Hedef sol tablodur ve Kaynak sağ tablodur. Dört olası kombinasyon şu kuralları verir:

  • Kaynak'taki AÇIK alan (lar), Hedefteki AÇIK alanlarla eşleşirse, GÜNCELLEME
  • Kaynaktaki AÇIK alan (lar), Hedefteki AÇIK alan (lar) la eşleşmiyorsa, EKLE
  • AÇIK alan (lar) Kaynakta yoksa ancak Hedefte mevcutsa, herhangi bir eylem gerçekleştirilmez.
  • AÇIK alan (lar) Kaynakta veya Hedefte yoksa, herhangi bir işlem gerçekleştirilmez.

Birden fazla Kaynak satırı belirli bir Hedef satırıyla eşleşirse, SQL: 2003 standartları tarafından bir hata zorunludur. Hedef satırı bir MERGE ifadesiyle birden çok kez güncelleyemezsiniz

Uygulamalar

Veritabanı Yönetim Sistemleri Oracle Veritabanı, DB2, Teradata, EXASOL, Firebird, CUBRID, HSQLDB, MS SQL, Vektörel ve Apache Derbisi standart sözdizimini destekler. Bazıları standart olmayan SQL uzantıları da ekler.

Eşanlamlı

Bazı veritabanı uygulamaları "Yukarı"(bir Portmanteau nın-nin Güncelleme ve eklemek) bir veri tabanı kayıt yoksa veritabanındaki bir tabloya kayıt ekleyen veya kayıt zaten mevcutsa mevcut kaydı güncelleyen ifade veya ifadelerin birleşimi. Bu eşanlamlı, PostgreSQL (v9.5 +)[1] ve SQLite (v3.24 +).[2] Aynı zamanda "MERGE" eşdeğeri sözde kodu kısaltmak için kullanılır.

Kullanılır Microsoft SQL Azure.[3]

Diğer standart dışı uygulamalar

Diğer bazı veritabanı yönetim sistemleri, kendi standart dışı SQL uzantıları aracılığıyla bunu veya çok benzer davranışı destekler.

MySQL, örneğin, kullanımını destekler INSERT ... AÇIK ÇİFTLEME ANAHTAR GÜNCELLEME sözdizimi[4] hedef ve kaynak arasındaki birleştirmenin yalnızca ANSI / ISO standardında gerekli olmayan PRIMARY KEY veya UNIQUE kısıtlamaları üzerinde yapılması gerektiği sınırlamasıyla benzer bir etki elde etmek için kullanılabilir. Ayrıca destekler ŞUNUNA DEĞİŞTİRİN sözdizimi,[5] ilk olarak bir eklemeyi dener ve bu başarısız olursa, varsa satırı siler ve ardından yenisini ekler. Ayrıca bir GÖZ ARDI ETMEK için madde INSERT Beyan,[6] bu, sunucuya "yinelenen anahtar" hatalarını yok saymasını ve devam etmesini söyler (mevcut satırlar eklenmeyecek veya güncellenmeyecektir, ancak tüm yeni satırlar eklenecektir).

SQLite 's INSERT VEYA DEĞİŞTİR INTO benzer şekilde çalışır. Ayrıca destekler ŞUNUNA DEĞİŞTİRİN MySQL ile uyumluluk için bir takma ad olarak.[7]

Firebird destekler BİRLEŞTİRMEK ancak, birden çok Kaynak veri satırı olduğunda bir hata atamaz. Ek olarak tek sıralı bir versiyon da mevcuttur, GÜNCELLEME VEYA INSERT INTO Tablo ismi (sütunlar) DEĞERLER (değerler) [EŞLEŞTİRME (sütunlar)], ancak ikincisi size ekleme ile güncellemeye karşı farklı işlemler yapma seçeneği sunmaz (örneğin, mevcut olanlar için değil, yalnızca yeni satırlar için yeni bir sıra değeri ayarlama).

IBM DB2 sözdizimini birden çok EŞLEŞTİĞİNDE ve EŞLEŞMEDİĞİ ZAMAN cümlecikler, onları ayıran ... VE bazı şartlar muhafızlar.

Microsoft SQL Sunucusu destekleyici korumalarla ve ayrıca Sol Birleştirme yoluyla desteklenir NE ZAMANDEĞİLEŞLEŞTİRİLDİTARAFINDANKAYNAK maddeleri.

PostgreSQL ile birleştirmeyi destekler INSERT INTO ... AÇIK FİKİR AYRILIĞI [ çatışma_hedefi ] çatışma_yönetim.[8]

CUBRID destekler BİRLEŞTİRMEK[9] Beyan. Ve kullanımını destekler INSERT ... AÇIK ÇİFTLEME ANAHTAR GÜNCELLEME sözdizimi.[10] Ayrıca destekler ŞUNUNA DEĞİŞTİRİN MySQL ile uyumluluk için.[11]

Apache Phoenix destekler UPSERT DEĞERLERİ[12] ve UPSERT SEÇİMİ[13] sözdizimi.

Spark SQL destekler GÜNCELLEME SETİ * ve EKLE * eylemlerdeki maddeler.[14]

Apache Impala destekler UPSERT INTO ... SEÇ[15].

NoSQL'de Kullanım

Bazılarında benzer bir kavram uygulanır. NoSQL veritabanları.

Örneğin. içinde MongoDB bir anahtarla ilişkilendirilmiş bir değerdeki alanlar bir Güncelleme operasyon. Güncelleme anahtar bulunmazsa bir hata yapar. Güncelleme işlemi ayarlamak mümkündür yükseltmek bayrak: bu durumda, eğer mevcut değilse, verilen anahtarla ilişkili yeni bir değer saklanır, aksi takdirde tüm değer değiştirilir.

İçinde Redis AYARLAMAK işlemler, belirli bir anahtarla ilişkili değeri ayarlar. Redis, değerin iç yapısının herhangi bir detayını bilmediğinden, Güncelleme hiçbir anlamı olmayacaktı. Böylece AYARLAMAK operasyon her zaman bir ayarla veya değiştir anlambilim.

Ayrıca bakınız

Referanslar

  1. ^ PostgreSQL öğretici
  2. ^ yükseltmek sqlite.org, 6-6-2018'i ziyaret etti
  3. ^ Transact-SQL Referansı (Veritabanı Motoru): MERGE (Transact-SQL)
  4. ^ MySQL :: MySQL 5.1 Başvuru Kılavuzu :: 12.2.4.3 INSERT ... ON DUPLICATE KEY UPDATE Sözdizimi
  5. ^ MySQL 5.1 Referans Kılavuzu: 11.2.6 REPLACE Sözdizimi
  6. ^ "MySQL 5.5 Referans Kılavuzu :: 13.2.5 INSERT Sözdizimi". Alındı 29 Ekim 2013.
  7. ^ "SQLite Tarafından Anlaşıldığı Gibi SQL: INSERT". Alındı 2012-09-27.
  8. ^ PostgreSQL INSERT sayfası
  9. ^ "Yeni CUBRID 9.0.0". CUBRID Resmi Blogu. 2012-10-30. Alındı 2012-11-08.
  10. ^ CUBRID :: Veri Manipülasyon İfadeleri :: Ekle :: ON DUPLICATE ANAHTAR GÜNCELLEME İfadesi
  11. ^ CUBRID :: Veri İşleme İfadeleri :: Değiştir
  12. ^ "UPSERT DEĞERLERİ".
  13. ^ "UPSERT SEÇİMİ".
  14. ^ "BİRLEŞMEK (Databricks üzerinde Delta Gölü)".
  15. ^ "UPSERT Beyanı (Apache Impala Belgeleri)".

Dış bağlantılar