Queryprestaties verbeteren in PostgreSQL
Amy McCarty
Instructor
Query

Query(plan)



Wat zijn joins?
Wat zijn joins?
Waarom joins?
Hoe?
| Sales ID | Order Dt | Amt | Cust No |
|---|---|---|---|
| 01 | 2019-02-02 | 145.30 | 911 |
| ID | Name | Customer Since |
|---|---|---|
| 911 | Jim Smith | 2019-01-01 |
| Sales ID | Order Dt | Amt | Name |
|---|---|---|---|
| 01 | 2019-02-02 | 145.30 | Jim Smith |

SELECT *
FROM athletes a
INNER JOIN countries c
ON a.country = c.country
| Atleet | Land | Land1 | Naam | Bev (mln) |
|---|---|---|---|---|
| Jack | AUT | AUT | Oostenrijk | 9 |
| Aditya | IND | IND | India | 1.339 |
| Mikhail | RUS | RUS | Rusland | 145 |

SELECT *
FROM athletes a
INNER JOIN countries c
ON a.country = c.country
| Atleet | Land | Land1 | Naam | Bev (mln) |
|---|---|---|---|---|
| Jack | AUT | AUT | Oostenrijk | 9 |
| Aditya | IND | IND | India | 1.339 |
| Mikhail | RUS | RUS | Rusland | 145 |

SELECT *
FROM athletes
INNER JOIN countries
USING (country)
| Atleet | Land | Naam | Bev (mln) |
|---|---|---|---|
| Jack | AUT | Oostenrijk | 9 |
| Aditya | IND | India | 1.339 |
| Mikhail | RUS | Rusland | 145 |

SELECT *
FROM athletes
INNER JOIN countries
USING (country)
| Atleet | Land | Naam | Bev (mln) |
|---|---|---|---|
| Jack | AUT | Oostenrijk | 9 |
| Aditya | IND | India | 1.339 |
| Mikhail | RUS | Rusland | 145 |

SELECT *
FROM athletes a
LEFT JOIN countries c
ON a.country = c.country
| Atleet | Land | Land1 | Naam | Bev (mln) | |
|---|---|---|---|---|---|
| Jack | AUT | AUT | Oostenrijk | 9 | |
| Aditya | IND | IND | India | 1.339 | |
| Mikhail | RUS | RUS | Rusland | 145 | |
| Javier | MEX |

SELECT *
FROM athletes a
LEFT JOIN countries c
ON a.country = c.country
| Atleet | Land | Land1 | Naam | Bev (mln) |
|---|---|---|---|---|
| Jack | AUT | AUT | Oostenrijk | 9 |
| Aditya | IND | IND | India | 1.339 |
| Mikhail | RUS | RUS | Rusland | 145 |
| Javier | MEX |

SELECT *
FROM athletes a
RIGHT JOIN countries c
ON a.country = c.country
| Atleet | Land | Land1 | Naam | Bev (mln) |
|---|---|---|---|---|
| Jack | AUT | AUT | Oostenrijk | 9 |
| Aditya | IND | IND | India | 1.339 |
| Mikhail | RUS | RUS | Rusland | 145 |
| BRA | Brazilië | 209 |

SELECT *
FROM athletes a
RIGHT JOIN countries c
ON a.country = c.country
| Atleet | Land | Land1 | Naam | Bev (mln) |
|---|---|---|---|---|
| Jack | AUT | AUT | Oostenrijk | 9 |
| Aditya | IND | IND | India | 1.339 |
| Mikhail | RUS | RUS | Rusland | 145 |
| BRA | Brazilië | 209 |
SELECT *
FROM athletes a
FULL OUTER JOIN countries c
ON a.country = c.country

| Atleet Nm | Land | Land1 | Naam | Bev (mln) |
|---|---|---|---|---|
| Jack | AUT | AUT | Oostenrijk | 9 |
| Aditya | IND | IND | India | 1.339 |
| Mikhail | RUS | RUS | Rusland | 145 |
| Javier | MEX | |||
| BRA | Brazilië | 209 |
Queryprestaties verbeteren in PostgreSQL