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