PostgreSQL for utviklere

Introduksjon

Dette er et kurs i systemutvikling med PostgreSQL som databasehåndteringssystem. Kurset passer godt for deg som skal jobbe med PostgreSQL i utviklingsprosjekter, og som har litt kjennskap til SQL fra før.

Målsetting

Gjøre deltakerne fortrolige med å programmere mot PostgreSQL i utviklingsprosjekter

Forkunnskaper

Kurset krever ingen forkunnskaper annet enn generell datakunnskap, men noe kjennskap til databaser og SQL vil være en fordel. Kurset vil såvidt mulig bli tilpasset deltakernes forkunnskaper.

Kursinnhold

Dag 1 – PostgreSQL og PostgreSQLs implementering av SQL

  • Introduksjon til PostgreSQL, databasens historikk, særtrekk og tilknyttede verktøy og utvidelser, inkludert pgAdmin4, Azure Data Studio og terminalklienten psql.
  • Anatomien til en PostgreSQL database
  • PostgreSQLs Datatyper – inkludert støtte for arrays, JSON og XML
  • Bruk av schema i PostgreSQL og search path i psql
  • Oppretting av brukere og brukerroller, databaser og tabeller, inkludert ulike metoder for generering av selvøkende felt.
  • Insetting av rader i tabeller, oppdatering av felt, sletting av rader og tabeller.
  • Importering og eksportering av data
  • Innebygde funksjoner for behandling av tekst, tall, dato og tid
  • SELECT – med underspørringer, Joins, Case When, Common Table Expressions og Vindusfunksjoner
  • Ulike typer Indekser og effekten av dem (btree, gin, gist)
  • Bruk av explain analyze og vacuum
  • Views og materalized views.

Dag 2 – Transaksjoner, brukerdefinerte funksjoner, lagrede prosedyrer, triggere, fulltekstsøk og foreign data wrappers

  • PostgreSQLs implementering av transaksjoner
  • SQL-baserte funksjoner
  • PL/pgSQL-baserte funksjoner
  • Funksjoner basert på andre språk (python, perl mm)
  • Triggerfunksjoner og triggere
  • Lagrede prosedyrer – fra og med PostgreSQL 11
  • Foreign Data Wrappers – hvordan koble inn tabeller fra andre databasehåndteringssystemer og bruke dem i PostgreSQL.
  • Fulltekstsøk (Natural Language Processing) med PostgreSQL
  • Programmering mot PostgreSQL med andre språk
    • Java, Scala og andre JVM-baserte språk med JDBC
    • Python med psycopg2
    • C (libpq), C++ (libpqxx)
    • C# og .NET med ODBC
    • JavaScript med pg.js

Gjennomføring

Kurset gjennomføres  med en kombinasjon av online læringsmidler, gjennomgang av temaer og problemstillinger og praktiske øvelser. Det er ingen avsluttende eksamen, men det er øvingsoppgaver til hvert av hovedtemaene som gjennomgås.

  • Kurset kan tas som klasseromskurs med lærer over 2 dager.
  • Kurset kan tas som bedriftsinternt kurs
  • Så lenge kororna-restriksjoner er aktuelt tilbys kurset som et todagers online kurs med lærer.

Datoer og Påmelding

Online kurs holdes disse datoene:

OKTOBER 2020
15.10 – 16.10 – To dager kl 10.00 – 15.00 hver dag
NOVEMBER 2020
11.11 – 12.11 – To dager kl 10.00 – 15. 00 hver dag
DESEMBER 2020
02.12 – 03.12 – To dager kl 10.00 – 15. 00 hver dag

Pris

kr. 10.500 pr deltaker. 

Bestilling av kurs

Kurs bestilles via en epost til kurs@itfakultetet.no. Oppgi navn og epost på deltakerne og hvilke datoer man ønsker kurset gjennomført. Alle våre kurs gjennomføres som online kurs med lærer inntil videre, pga pandemi-situasjonen. Vi bruker Microsoft Teams og vår egen online e-læringsportal til kursene.

Betaling av kurs

Etter bestilling sender vi en epost med kursinformasjon og en elektronisk faktura. Kursavgiften skal være fullt innbetalt før kursstart, men unntak kan gjøres ved behov.

Ved bedriftsinterne kurs eller hvor det meldes på mer enn 3 deltakere fra samme bedrift, kan et depositum utgjørende 2 hele kursavgifter erstatte full betaling før start, og resterende kan etterfaktureres.

Merk: Kurs og opplæring er fritatt for mva.

Avlysning av kurs

Dersom kursdeltakelse avlyses pga. sykdom e.l. senest 3 dager før kursstart, refunderes 75% av kursavgiften. Etter dette refunderes 50% av kursavgiften ved avlysning. Epost er gyldig medium for avlysning av kurs. Send en epost til: kurs@itfakultetet.no og spesifiser hvilket kurs du ikke kan komme på.