Vermijd veelgemaakte fouten

SQL toepassen op problemen uit de praktijk

Dmitriy (Dima) Gorenshteyn

Lead Data Scientist, Memorial Sloan Kettering Cancer Center

Misbruik comments niet

/* Bij het selecteren van category en length
uit films moeten we f gebruiken; daarna
at ik een sandwich, het was een
goede sandwich ...*/
SELECT category, length
-- FROM actor as a
FROM film AS f
/* Inner join van category
met de tabel film */
INNER JOIN category AS c
ON f.film_id = c.film_id;

Niet doen

  • Schrijf een heel verhaal in je comments.
SQL toepassen op problemen uit de praktijk

Misbruik comments niet





SELECT category, length
-- FROM actor as a
FROM film AS f
/* Inner join van category
met de tabel film */
INNER JOIN category AS c
ON f.film_id = c.film_id;

Niet doen

  • Schrijf een heel verhaal in je comments.
  • Laat oude comments staan in afgeronde code.
SQL toepassen op problemen uit de praktijk

Misbruik comments niet





SELECT category, length

FROM film AS f
/* Inner join van category
met de tabel film */
INNER JOIN category AS c
ON f.film_id = c.film_id;

Niet doen

  • Schrijf een heel verhaal in je comments.
  • Laat oude comments staan in afgeronde code.
  • Maak comments die dubbelop zijn met code.
SQL toepassen op problemen uit de praktijk

Misbruik comments niet

/* Bij het selecteren van category en length
uit films moeten we f gebruiken; daarna
at ik een sandwich, het was een
goede sandwich ...*/
SELECT category, length
-- FROM actor as a
FROM film AS f
/* Inner join van category
met de tabel film */
INNER JOIN category AS c
ON f.film_id = c.film_id;
SELECT category, length
FROM film AS f
INNER JOIN category AS c
ON f.film_id = c.film_id;
SQL toepassen op problemen uit de praktijk

SELECT niet alles

SELECT *
FROM film AS f
INNER JOIN category AS c
ON f.film_id = c.film_id;
release_year language_id rental_duration rental_rate length  .......
2009            1            4              6.99        173  .......    
2006            1            7              6.99        185  .......    
2004            1            5              4.99        153  .......    
2007            1            7              2.99        69   .......
SQL toepassen op problemen uit de praktijk

Gebruik SQL niet om te programmeren

DO $$
BEGIN
   FOR counter IN 1..5 LOOP
     IF (counter = 2) THEN
      RAISE NOTICE 'BINGO!';
     ELSE 
      RAISE NOTICE 'Geen BINGO :-(';
     END IF;
   END LOOP;
END; $$
NOTICE:  1 Geen BINGO :-(
NOTICE:  1 BINGO!
NOTICE:  3 Geen BINGO :-(
NOTICE:  4 Geen BINGO :-(
NOTICE:  5 Geen BINGO :-(
SQL toepassen op problemen uit de praktijk

Laten we oefenen!

SQL toepassen op problemen uit de praktijk

Preparing Video For Download...