SQLite - BİRLEŞİMLER

SQLite Joinsyan tümcesi, bir veritabanındaki iki veya daha fazla tablodaki kayıtları birleştirmek için kullanılır. BİRLEŞTİRME, her biri için ortak olan değerleri kullanarak iki tablodan alanları birleştirmek için bir araçtır.

SQL, üç ana birleştirme türünü tanımlar -

  • CROSS JOIN
  • İÇ BİRLEŞTİRME
  • OUTER JOIN

Devam etmeden önce, ŞİRKET ve BÖLÜM olmak üzere iki tabloyu ele alalım. COMPANY tablosunu doldurmak için INSERT ifadeleri gördük. Öyleyse, COMPANY tablosunda bulunan kayıtların listesini varsayalım -

ID          NAME        AGE         ADDRESS     SALARY
----------  ----------  ----------  ----------  ----------
1           Paul        32          California  20000.0
2           Allen       25          Texas       15000.0
3           Teddy       23          Norway      20000.0
4           Mark        25          Rich-Mond   65000.0
5           David       27          Texas       85000.0
6           Kim         22          South-Hall  45000.0
7           James       24          Houston     10000.0

Başka bir tablo, aşağıdaki tanıma sahip DEPARTMENT'tır -

CREATE TABLE DEPARTMENT(
   ID INT PRIMARY KEY      NOT NULL,
   DEPT           CHAR(50) NOT NULL,
   EMP_ID         INT      NOT NULL
);

DEPARTMENT tablosunu doldurmak için INSERT deyimlerinin listesi aşağıdadır -

INSERT INTO DEPARTMENT (ID, DEPT, EMP_ID)
VALUES (1, 'IT Billing', 1 );

INSERT INTO DEPARTMENT (ID, DEPT, EMP_ID)
VALUES (2, 'Engineering', 2 );

INSERT INTO DEPARTMENT (ID, DEPT, EMP_ID)
VALUES (3, 'Finance', 7 );

Son olarak, DEPARTMENT tablosunda bulunan aşağıdaki kayıtların listesine sahibiz -

ID          DEPT        EMP_ID
----------  ----------  ----------
1           IT Billing  1
2           Engineering 2
3           Finance     7

CROSS JOIN

CROSS JOIN, ilk tablonun her satırını ikinci tablonun her satırıyla eşleştirir. Giriş tablolarında sırasıyla x ve y satırı varsa, ortaya çıkan tablo x * y satırına sahip olacaktır. CROSS JOIN'lerin çok büyük tablolar oluşturma potansiyeli olduğundan, bunları yalnızca uygun olduğunda kullanmaya özen gösterilmelidir.

CROSS JOIN sözdizimi aşağıdadır -

SELECT ... FROM table1 CROSS JOIN table2 ...

Yukarıdaki tablolara dayanarak, aşağıdaki gibi bir CROSS JOIN yazabilirsiniz -

sqlite> SELECT EMP_ID, NAME, DEPT FROM COMPANY CROSS JOIN DEPARTMENT;

Yukarıdaki sorgu aşağıdaki sonucu verecektir -

EMP_ID      NAME        DEPT
----------  ----------  ----------
1           Paul        IT Billing
2           Paul        Engineering
7           Paul        Finance
1           Allen       IT Billing
2           Allen       Engineering
7           Allen       Finance
1           Teddy       IT Billing
2           Teddy       Engineering
7           Teddy       Finance
1           Mark        IT Billing
2           Mark        Engineering
7           Mark        Finance
1           David       IT Billing
2           David       Engineering
7           David       Finance
1           Kim         IT Billing
2           Kim         Engineering
7           Kim         Finance
1           James       IT Billing
2           James       Engineering
7           James       Finance

İÇ BİRLEŞTİRME

INNER JOIN, iki tablonun (tablo1 ve tablo2) sütun değerlerini birleştirme koşuluna göre birleştirerek yeni bir sonuç tablosu oluşturur. Sorgu, birleşim koşulunu karşılayan tüm satır çiftlerini bulmak için tablo1'in her satırını her tablo2 satırıyla karşılaştırır. Birleştirme koşulu karşılandığında, eşleşen her A ve B satır çiftinin sütun değerleri bir sonuç satırında birleştirilir.

INNER JOIN, en yaygın ve varsayılan birleştirme türüdür. INNER anahtar kelimesini isteğe bağlı olarak kullanabilirsiniz.

INNER JOIN sözdizimi aşağıdadır -

SELECT ... FROM table1 [INNER] JOIN table2 ON conditional_expression ...

Fazlalıktan kaçınmak ve cümleleri daha kısa tutmak için, INNER JOIN koşulları bir USINGifade. Bu ifade, bir veya daha fazla sütunun bir listesini belirtir.

SELECT ... FROM table1 JOIN table2 USING ( column1 ,... ) ...

NATURAL JOIN, JOIN...USING, yalnızca her iki tabloda bulunan her sütunun değerleri arasındaki eşitliği otomatik olarak test eder -

SELECT ... FROM table1 NATURAL JOIN table2...

Yukarıdaki tablolara dayanarak, aşağıdaki gibi bir INNER JOIN yazabilirsiniz -

sqlite> SELECT EMP_ID, NAME, DEPT FROM COMPANY INNER JOIN DEPARTMENT
   ON COMPANY.ID = DEPARTMENT.EMP_ID;

Yukarıdaki sorgu aşağıdaki sonucu verecektir -

EMP_ID      NAME        DEPT
----------  ----------  ----------
1           Paul        IT Billing
2           Allen       Engineering
7           James       Finance

OUTER JOIN

OUTER JOIN, INNER JOIN'in bir uzantısıdır. SQL standardı üç tip OUTER JOIN tanımlasa da: LEFT, RIGHT ve FULL, SQLite yalnızcaLEFT OUTER JOIN.

OUTER JOIN'ler, INNER JOIN'lerle aynı olan ve bir ON, USING veya NATURAL anahtar sözcüğü kullanılarak ifade edilen bir koşula sahiptir. İlk sonuç tablosu aynı şekilde hesaplanır. Birincil BİRLEŞTİRME hesaplandıktan sonra, bir DIŞ BİRLEŞTİRME, bir veya her iki tablodan birleştirilmemiş tüm satırları alır, bunları NULL'larla doldurur ve sonuç tabloya ekler.

LEFT OUTER JOIN'in sözdizimi aşağıdadır -

SELECT ... FROM table1 LEFT OUTER JOIN table2 ON conditional_expression ...

Fazlalıktan kaçınmak ve ifadeyi daha kısa tutmak için OUTER JOIN koşulları bir KULLANIM ifadesiyle bildirilebilir. Bu ifade, bir veya daha fazla sütunun bir listesini belirtir.

SELECT ... FROM table1 LEFT OUTER JOIN table2 USING ( column1 ,... ) ...

Yukarıdaki tablolara dayanarak, aşağıdaki gibi bir iç birleşim yazabilirsiniz -

sqlite> SELECT EMP_ID, NAME, DEPT FROM COMPANY LEFT OUTER JOIN DEPARTMENT
   ON COMPANY.ID = DEPARTMENT.EMP_ID;

Yukarıdaki sorgu aşağıdaki sonucu verecektir -

EMP_ID      NAME        DEPT
----------  ----------  ----------
1           Paul        IT Billing
2           Allen       Engineering
            Teddy
            Mark
            David
            Kim
7           James       Finance