Effektiv eksekvering av spørsmål

Like dokumenter
Effektiv eksekvering av spørsmål

Effektiv eksekvering av spørsmål

Effektiv eksekvering av spørsmål

Effektiv eksekvering av spørsmål

Spørsmålskompilering del 2

Spørsmålskompilering del 1

Spørsmålskompilering del 1

Spørsmålskompilering del 2

DBS18 - Strategier for Query-prosessering

UNIVERSITETET. Indeksering. Konvensjonelle indekser B-trær og hashing Flerdimensjonale indekser Hashliknende strukturer.

Spørsmålskompilering

INF3100 V2018 Obligatorisk oppgave nr. 2

Spørsmålskompilering. Basert på foiler av Hector Garcia-Molina

UNIVERSITETET I OSLO. Indeksering. Hvordan finne et element raskt? Institutt for Informatikk. INF Ellen Munthe-Kaas

Indeksering. Konvensjonelle indekser B-trær og hashing Flerdimensjonale indekser Treliknende strukturer Hashliknende strukturer Bitmapindekser

UNIVERSITETET I OSLO RELASJONSALGEBRA. Regning med relasjoner. Institutt for Informatikk. INF Ellen Munthe-Kaas 1

INF1300 Relasjonsalgebra og SQL, mengder og bager. Lysark for forelesning v. 2.1

Indeksering. Konvensjonelle indekser B-trær og hashing Flerdimensjonale indekser Trestrukturer Hashliknende strukturer Bitmapindekser

Indeksering. Konvensjonelle indekser B-trær og hashing Flerdimensjonale indekser Trestrukturer Hashliknende strukturer Bitmapindekser

INF1300 Introduksjon til databaser

UNIVERSITETET RELASJONSALGEBRA. Regning g med relasjoner. Institutt for Informatikk. INF Ellen Munthe-Kaas 1

Relasjonsalgebraen. Algebra

Spørsmålskompilering. Basert på foiler av Hector Garcia-Molina

UNIVERSITETET I OSLO RELASJONSALGEBRA. Regning med relasjoner. Institutt for Informatikk. INF Ragnar Normann

UNIVERSITETET. Indeksering. Hvordan finne et element raskt? Vera Goebel, Ellen Munthe-Kaas

UNIVERSITETET I OSLO RELASJONSALGEBRA. Regning med relasjoner. Institutt for Informatikk INF Ellen Munthe-Kaas

UNIVERSITETET I OSLO RELASJONSALGEBRA. Regning med relasjoner. Institutt for Informatikk INF Ellen Munthe-Kaas

Oppgave 1a Definer følgende begreper: Nøkkel, supernøkkel og funksjonell avhengighet.

Repetisjonsforelesning, SQL og utover

UNIVERSITETET I OSLO RELASJONSALGEBRA. Regning med relasjoner. Institutt for Informatikk. INF Ellen Munthe-Kaas

Relasjonsalgebra Kopi av lysark om relasjonsalgebra. Vi går igjennom denne for å lage et matematisk fundament for forståelsen av hvordan

INF1300 Relasjonsalgebra. Et matematisk fundament for å forstå SQL-setninger

Logaritmiske sorteringsalgoritmer

Hvor raskt klarer vi å sortere?

Andre sett obligatoriske oppgaver iinf3100v2011

UNIVERSITETET I OSLO SQL. Structured Query Language. (forts.) Institutt for Informatikk. INF Ragnar Normann 1

UNIVERSITETET I OSLO. Oppskriftsbok. FDer og MVDer Relasjonsalgebra. Institutt for Informatikk. INF3100 Ellen Munthe-Kaas 1

INF2220: Time 12 - Sortering

Oppskriftsbok. FDer og MVDer - oversikt: se s. 3 Relasjonsalgebra - oversikt: se s. 45

UNIVERSITETET I OSLO SQL. Structured Query Language. (The intergalactic dataspeak) Institutt for Informatikk. INF Ragnar Normann 1

Andre sett obligatoriske oppgaver i INF3100 V2012

Heapsort. Lars Vidar Magnusson Kapittel 6 Heaps Heapsort Prioritetskøer

Sorteringsproblemet. Gitt en array A med n elementer som kan sammenlignes med hverandre:

Andre sett obligatoriske oppgaver i INF3100 V2013

Oppgave 1 a. INF1020 Algoritmer og datastrukturer. Oppgave 1 b

UNIVERSITETET. Relasjonsalgebra. INF Ragnhild Kobro Runde

IN3020 V2019 Obligatorisk oppgave nr. 1

Isolasjon i postgres og mysql

INF Algoritmer og datastrukturer

Eksamensoppgave i TDT4225 Lagring og behandling av store datamengder

Først litt praktisk info. Sorteringsmetoder. Nordisk mesterskap i programmering (NCPC) Agenda

Obligatorisk oppgave 1 INF1020 h2005

UNIVERSITETET SQL. Structured Query Language (forts.) Institutt for Informatikk. INF Ellen Munthe-Kaas 1

deeegimnoorrrsstt Sjette forelesning

Oppgave 1 Datamodellering 25 %

Generelle Tips. INF Algoritmer og datastrukturer. Åpen og Lukket Hashing. Hashfunksjoner. Du blir bedømt etter hva du viser at du kan

n/b log b n = (lg n) a log b n = n log b a

NITH PG4200 Algoritmer og datastrukturer Løsningsforslag Eksamen 4.juni 2013

UNIVERSITETET I OSLO

UNIVERSITETET I OSLO SQL. Structured Query Language. (forts.) Institutt for Informatikk. INF Ellen Munthe-Kaas 1

Python: Rekursjon (og programmering av algoritmer) Python-bok: Kapittel 12 + teoribok om Algoritmer

TDT4225 Lagring og behandling av store datamengder

INF1020 Algoritmer og datastrukturer

INF2220: Forelesning 2

Øvingsforelesning 6. Sorteringsalgoritmer. Kristian Veøy

Databaser. Relasjonsmodellen 2 Læreboka: Kap. 2 Relasjonsmodellen

IN Algoritmer og datastrukturer

INF Algoritmer og datastrukturer

TDT4105 Informasjonsteknologi, grunnkurs

Løsningsskisse til eksamensoppgave i TDT4145 Datamodellering og databasesystemer

Søkeproblemet. Gitt en datastruktur med n elementer: Finnes et bestemt element (eller en bestemt verdi) x lagret i datastrukturen eller ikke?

INF Algoritmer og datastrukturer

INF Algoritmer og datastrukturer

UNIVERSITETET I OSLO

Databaser fra et logikkperspektiv

Datastrukturer for rask søking

Hashing. INF Algoritmer og datastrukturer HASHING. Hashtabeller

Øvingsforelesning 3: Splitt og hersk. Daniel Solberg

D: Ingen trykte eller håndskrevne hjelpemiddel tillatt. Bestemt, enkel kalkulator tillatt.

Normalisering. ER-modell

Notater til INF2220 Eksamen

Binær heap. En heap er et komplett binært tre:

INF1010 notat: Binærsøking og quicksort

Binære trær: Noen algoritmer og anvendelser

UNIVERSITETET I OSLO SQL. Structured Query Language. (The intergalactic dataspeak) Institutt for Informatikk. INF Ellen Munthe-Kaas 1

Relasjonsdatabasedesign

Dagens temaer. Kort repetisjon. Mer om cache (1) Mer om cache (2) Read hit. Read miss. Write hit. Hurtig minne. Cache

Heap* En heap er et komplett binært tre: En heap er også et monotont binært tre:

Oppgave 1 ER- og relasjonsmodell 10 %

INF Algoritmer og datastrukturer

En lett innføring i foreninger (JOINs) i SQL

INF Algoritmer og datastrukturer

UNIVERSITETET I OSLO SQL. Structured Query Language. (The intergalactic dataspeak) INF Ellen Munthe-Kaas 1. Institutt for Informatikk

UNIVERSITETET. Relasjonsdatabasedesign

Oppgave 1. Sekvenser (20%)

Integritetsregler i SQL

NITH PG4200 Algoritmer og datastrukturer Løsningsforslag Eksamen 4.juni 2013

Integritetsregler i SQL. Primærnøkler

INF2220: Gruppe me 2. Mathias Lohne Høsten 2017

Hashing: Håndtering av kollisjoner

Transkript:

UNIVERSITETET I OSLO Effektiv eksekvering av spørsmål Spørsmålshåndtering Modell for kostnadsberegning Kostnad for basisoperasjoner Implementasjonsalgoritmer Institutt for Informatikk INF3100 V18 Evgenij Thorstensen 1

Spørsmålshåndtering SQL-spørring metadata Spørsmålskompilering Spørsmålseksekvering spørreplan data INF3100 V18 Evgenij Thorstensen 2

Spørsmålskompilering SQL-spørring Parsering parseringstre Optimalisering Omskriving logisk spørreplan Generering av data fysisk plan fysisk spørreplan Eksekvering av planen INF3100 V18 Evgenij Thorstensen 3

Fysiske operatorer En spørring består av et relasjonsalgebrauttrykk. En fysisk spørreplan implementeres av et sett operatorer (algoritmer) tilsvarende operatorene fra relasjonsalgebraen. I tillegg trenger vi basisoperatorer for å lese (skanne) en relasjon, sortere en relasjon osv. For å kunne velge en god plan, må vi kunne estimere kostnaden til hver operator. Vi vil bruke antall disk-io og antar generelt at operandene må initielt hentes fra disk resultatet brukes direkte fra primærminnet andre kostnader kan ignoreres INF3100 V18 Evgenij Thorstensen 4

Kostnadsparametre Hvilken mekanisme som har lavest kostnad, avhenger av flere faktorer, inkludert Antall tilgjengelige blokker i minnet, M Om det finnes indekser, og hva slags. Layout på disken og spesielle diskegenskaper.... For en relasjon R trenger vi i tillegg å vite Antall blokker som kreves for å lagre alle tuplene, B R Antall tupler i R, T R Antall distinkte verdier for et attributt A, V R (A) Gjennomsnittlig antall tupler som er like på A, er da T R /V R (A) INF3100 V18 Evgenij Thorstensen 5

Faktorer som øker kostnaden Bruk av indeks som ikke ligger i minnet. Ideelt sett ligger tuplene til en relasjon R tettpakket (clustered) og opptar derfor B R blokker. Men dette er ikke nødvendigvis tilfellet: Blokkene kan inneholde ledig plass for innsetting av nye tupler. Tuplene ligger spredt (scattered), f.eks. fordi de ligger lagret sammenfiltret med tupler fra andre relasjoner. Vi vil generelt ikke inkludere disse faktorene i våre estimater. INF3100 V18 Evgenij Thorstensen 6

Kostnad for basisoperasjoner Kostnaden for å lese en diskblokk er 1 disk-io Kostnaden for å skrive en diskblokk er 1 disk-io Oppdatering koster 2 disk-io Tre fundamentale operasjoner: Usortert innlesning av en relasjon R: Kostnaden avhenger av lagringen Tettpakket (clustered) relasjon B R disk-io Spredt (scattered) relasjon worst-case T R disk-io Sortering Hashpartisjonering Vi vil generelt anta tettpakkede relasjoner. INF3100 V18 Evgenij Thorstensen 7

Kostnad for basisoperasjoner Vi husker at postgres skiller mellom sekvensiell read random read For data i minnet (joins av joins) er det ikke antall blokker, men antall tupler som gjelder I minnet er ting i alle fall tettpakkede, så blokker eller tupler er ikke så spennende. INF3100 V18 Evgenij Thorstensen 8

Innlesing og indekser I postgres er indekser tette: tabeller ligger generelt ikke sortert. Det betyr at indeksbruk er per tuppel, og reads er random reads. Å lese en hel tabell er en sekvensiell read. Indekser blir derfor ikke brukt hvis vi skal ha mange tupler. INF3100 V18 Evgenij Thorstensen 9

Bitmap heap scan I tillegg til kostnad for random read, kan samme blokk bli lest flere ganger. Dette er kjipt spesielt hvis vi har flere indekser. Bitmap heap scan fikser dette. Ide: Les indeks, finn blokknummer til alle tupler vi skal ha. Les riktige blokker i deres rekkefølge. INF3100 V18 Evgenij Thorstensen 10

Sortering Sort-scan leser en relasjon R og returnerer R i sortert rekkefølge mhp. en mengde attributter X. Hvis R har en B-tre-indeks på X, kan denne brukes til å traversere tuplene i R i sortert rekkefølge Hvis hele R får plass i minnet, bruk en effektiv sorteringsalgoritme kostnad B R disk-io Hvis R er for stor til å få plass i minnet, må vi bruke en sorteringsalgoritme som håndterer data i flere pass Ofte brukt: two-phase multiway merge sort (TPMMS) INF3100 V18 Evgenij Thorstensen 11

Two-Phase Multiway Merge Sort (TPMMS) Fase 1: Sorter deler av relasjonen (så mye som det er plass til i minnet om gangen). Fyll alle tilgjengelige minneblokker med blokker som inneholder relasjonen. Sorter dette utsnittet i minnet. Skriv det sorterte resultatet (en subliste) tilbake til disk. Gjenta til alle blokkene er lest og alle postene er sortert i sublister. Kostnad 2B R, dvs. alle blokkene er både lest og skrevet. INF3100 V18 Evgenij Thorstensen 12

Two-Phase Multiway Merge Sort (TPMMS) Fase 2: Flett (merge) alle de sorterte sublistene til én sortert liste ved gjentatt å gjøre følgende: Les den første blokken fra hver subliste inn i minnet og sammenlign det første elementet i hver blokk. Plasser det minste elementet i den endelige listen og fjern elementet fra sublisten. Hent inn nye blokker fra hver subliste ved behov. Kostnad: B R Total kostnad: 3B R Forutsetning: Antall sublister må være mindre eller lik antall tilgjengelige minneblokker: B R /M M, dvs. M B R INF3100 V18 Evgenij Thorstensen 13

Hashpartisjonering Hashfunksjonen samler tupler som skal ses på i sammenheng. Med M tilgjengelige buffere: Bruk M-1 buffere for buckets, 1 for å lese diskblokker Algoritme: for hver blokk b i relasjon R { les b inn i buffer M; for hvert tuppel t i b { if not plass i bucket h(t) { kopier bucket h(t) til disk; initialiser ny blokk for bucket h(t) }; kopier t til bucket h(t) }; } for hver ikketom bucket { skriv bucket til disk } Kostnad: 2B R les alle data og skriv dem partisjonert tilbake. (NB: Dette inkluderer altså skriving tilbake!) INF3100 V18 Evgenij Thorstensen 14

Eksekvering av spørsmål Tre hovedklasser med algoritmer: sorteringsbaserte hashbaserte indeksbaserte I tillegg kan kostnad og kompleksitet deles inn i ulike nivåer en-passalgoritmer data passer i minnet, leses bare en gang fra disk. to-passalgoritmer data for stort for minnet, les data, prosesser, skriv tilbake, les på nytt n-passalgoritmer rekursive generaliseringer av to-passalgoritmer for metoder som trenger flere pass over hele datasettet INF3100 V18 Evgenij Thorstensen 15

Ulike grupper operatorer Tuppel-om-gangen, unære operasjoner: seleksjon ( ) projeksjon ( ) Full-relasjon, unære operasjoner: gruppering ( ) duplikat-eliminasjon ( ) Binære operasjoner: sett og bag union ( ) sett og bag snitt ( ) sett og bag differanse ( ) join ( ) produkt ( ) INF3100 V18 Evgenij Thorstensen Vi skal se på flere måter å implementere disse operatorene ved hjelp av ulike algoritmer og ulike antall pass. Merk at vi bare foreleser utvalgte deler og oppsummeringer! For flere algoritmer, se læreboken 16

Seleksjon og projeksjon Både seleksjon ( ) og projeksjon ( ) har opplagte algoritmer uavhengig av om relasjonen passer i minnet eller ikke: Hent en og en blokk inn i minnet og prosesser hvert tuppel i blokken. Eneste krav til minnet er M 1 for inputbufferet. Kostnaden avhenger av hvor R ligger: i minnet 0 på disk i verste fall B R disk-io INF3100 V18 Evgenij Thorstensen 17

Seleksjon: Eksempel T R = 20.000, B R = 1000, A=v (R) Ingen indeks på A hent alle blokkene 1000 disk-io Clusterindeks på A hent B R / V R (A) blokker V R (A) = 100 1000 / 100 = 10 disk-io V R (A) = 10 1000 / 10 = 100 disk-io V R (A) = 20.000, dvs. A er en kandidatnøkkel 1 disk-io INF3100 V18 Evgenij Thorstensen 18

Oppsummering: Kostnad og minnekrav for seleksjon A=v (R) Algoritme Minnekrav Disk-IO Ingen indeks på A M 1 B R Clusterindeks på A M 1 B R / V R (A) INF3100 V18 Evgenij Thorstensen 19

Oppsummering: Kostnad og minnekrav for projeksjon L (R) Minnekrav M 1 Disk-IO B R INF3100 V18 Evgenij Thorstensen 20

Duplikateliminasjon ( ): En-pass Duplikateliminasjon ( ) kan utføres ved å lese en blokk om gangen og for hvert tuppel kopiere til output-buffer hvis det er første forekomst ignorere hvis vi har sett et duplikat Krever en kopi av hvert tuppel i minnet for sammenligning. Total kostnad: B R Minnekrav: 1 blokk til R, B (R) blokker til å holde en kopi av hvert tuppel der (R) er antall forskjellige tupler i R, så M 1 + B (R) INF3100 V18 Evgenij Thorstensen 21

Duplikateliminasjon ( ): To-pass Sorteringsbasert algoritme: Tilsvarende Two-Phase Multiway Merge Sort (TPMMS) Les M blokker inn i minnet av gangen. Sorter disse M blokkene og skriv sublisten til disk. I stedet for å flette sublistene, kopier første tuppel og eliminer duplikater i front av sublistene. Hashbasert algoritme: Partisjoner relasjonen. Duplikate tupler vil ha samme hashverdi. Les hver bucket inn i minnet og utfør en-pass-algoritmen som fjerner duplikater. INF3100 V18 Evgenij Thorstensen 22

Oppsummering: Kostnad og minnekrav for duplikateliminasjon (R) Algoritme Minnekrav Disk-IO En-Pass M 1 + B (R) B R To-Pass Sortering M B R 3B R To-Pass Hashing M B R 3B R INF3100 V18 Evgenij Thorstensen 23

Oppsummering: Kostnad og minnekrav for gruppering (R) Algoritme Minnekrav Disk-IO En-Pass M 1 + B (R) B R To-Pass Sortering M B R 3B R To-Pass Hashing M B R 3B R INF3100 V18 Evgenij Thorstensen 24

Binære operasjoner En binær operasjon tar to relasjoner som argumenter: union: R S snitt: R S differanse: R S join R S produkt: R S Merk at det er forskjell på set- og bagversjonene av disse operatorene. Vi skal se på algoritmer for set- og bagunion samt naturlig join; de resterende operatorene kan implementeres på tilsvarende måte Alle operasjoner som krever sammenligning, må bruke en søkestruktur (f.eks. binærtrær eller hashing) som også krever ressurser. Vi tar imidlertid ikke med disse i våre estimater. INF3100 V18 Evgenij Thorstensen 25

Union ( ) : En-pass Bag-union kan beregnes med en enkel en-pass algoritme: Les og kopier hvert tuppel i R til outputbufferet. Les og kopier hvert tuppel i S til outputbufferet. Total kostnad: B R + B S disk-io Minnekrav: 1 (les hver blokk direkte til outputbuffer) Set-union må fjerne duplikater Les den minste relasjonen (anta S) inn i M-1 buffere og kopier hvert tuppel til output, men behold S i minnet. Les blokkene i R inn i det siste bufferet, og sjekk for hvert tuppel om det eksisterer i S; hvis ikke, kopier til output Minnekrav: B S < M INF3100 V18 Evgenij Thorstensen 26

Union ( ) : To-pass, sortering Set-union to-pass sortering: Gjør fase 1 av TPMMS for hver av R og S (lag sorterte sublister). Bruk ett buffer for hver av sublistene til R og S. Gjenta: Finn minste gjenværende tuppel i hver subliste Output tuppelet. Fjern duplikater fra fronten av alle listene Total kostnad: 3B R + 3B S disk-io Minnekrav: M buffere gir rom for å lage sublister av lengde M blokker (B R + B S )/M M gir (B R +B S ) M Hvis B R + B S > M 2, får vi mer enn M sublister, og algoritmen vil ikke fungere. INF3100 V18 Evgenij Thorstensen 27

Union ( ) : To-pass, hashing Set-union to-pass hashalgoritme: Partisjoner både R og S i M-1 buckets med samme hashfunksjon. Gjør union på hvert bucketpar R i S i separat (en-pass setunion) Total kostnad: 3B R + 3B S disk-io 2 for partisjoneringen 1 for union av bucketpar Minnekrav: M buffere gir rom for å lage M-1 buckets for hver relasjon For hvert bucketpar R i og S i : enten B Ri M-1 eller B Si M-1 Tilnærmet min(b R, B S ) M 2, dvs. min(br, BS) M Hvis den minste av R i og S i ikke får plass i M-1 buffere for en i, vil algoritmen ikke fungere. INF3100 V18 Evgenij Thorstensen 28

Oppsummering: Kostnad og minnekrav for R S Hvis B S B R : BAG-versjon : SET-versjon : Algoritme Minnekrav Disk-IO En-Pass M 1 B R + B S Algoritme Minnekrav Disk-IO En-Pass M 1 + B S B R + B S To-Pass Sortering M (B R + B S ) 3B R + 3B S To-Pass Hashing M B S 3B R + 3B S INF3100 V18 Evgenij Thorstensen 29

Oppsummering: Kostnad og minnekrav for R S Hvis B S B R : Algoritme Minnekrav 1 Disk-IO En-Pass M 1 + B S B R + B S To-Pass Sortering M (B R + B S ) 3B R + 3B S To-Pass Hashing M B S 3B R + 3B S 1 BAG-versjonen trenger i tillegg plass til tuppeltellere. INF3100 V18 Evgenij Thorstensen 30

Oppsummering: Kostnad og minnekrav for R S Hvis B S B R : Algoritme Minnekrav 1 Disk-IO En-Pass M 1 + B S B R + B S To-Pass Sortering M (B R + B S ) 3B R + 3B S To-Pass Hashing M B S 3B R + 3B S 1 BAG-versjonen trenger i tillegg plass til tuppeltellere. INF3100 V18 Evgenij Thorstensen 31

Naturlig join ( ) : en-pass Naturlig join ( ) konkatenerer tupler fra R(X,Y) og S(Y,Z) som er slik at R.Y = S.Y En-pass-algoritme: Les den minste relasjonen (anta S) inn i M-1 buffere. Les relasjon R blokk for blokk. For hvert tuppel t Join t med matchende tupler i S Flytt resultatet til output Total kostnad: B R + B S disk-io Minnekrav: B S < M INF3100 V18 Evgenij Thorstensen 32

Naturlig join ( ) : Nestet loop join blokk-basert algoritme Hold så mye som mulig av den minste relasjonen i M-1 blokker Algoritme: (anta S minst) for hver partisjon p av S med størrelse M-1 { les p inn i minnet; for hver blokk b for R { les b inn i minnet; for hvert tuppel t i b { finn tupler i p som matcher t; join hver av disse med t til output }}} Total kostnad: B S + B R B S /(M - 1) disk-io. (Les S en gang, les R en gang for hver S-partisjon. Det blir B S /(M - 1) partisjoner rund av B S /(M - 1) oppover.) Minnekrav: 2 (en R-blokk og en S-blokk; størrelsen på S-partisjonene tilpasses M, så i verste fall er hver S-partisjon én blokk) INF3100 V18 Evgenij Thorstensen 33

Naturlig join ( ) : To-pass sortering enkel algoritme Sorter R og S hver for seg ved hjelp av TPMMS på joinattributtene. Join de sorterte R og S ved å Hvis et buffer for R eller S er tomt, hente ny blokk fra disk Finne tupler som har den minste v-verdien for join-attributtene (NB: Kan også finnes i påfølgende blokker; da må i såfall alle holdes i minnet!) Hvis det finnes v-verditupler i både R og S, joine disse og skrive til output Ellers: droppe alle v-verditupler. Total kostnad: 5B R + 5B S disk-io 4 for TPMMS (må skrive tilbake til disk før avsluttende join, så 4 snarere enn 3) 1 for å joine de sorterte R og S Minnekrav: TPMMS krever B M 2 for hver av relasjonene, dvs. B R M 2 og B S M 2 Hvis det finnes en v-verdi der tilhørende tupler ikke får plass i M blokker, virker ikke algoritmen. INF3100 V18 Evgenij Thorstensen 34

Naturlig join ( ) : To-pass hashing ( hash-join ) Algoritme: Partisjoner både R og S i M-1 buckets med samme hashfunksjon på joinattributtene Y. (Trenger 1 blokk til å holde fortløpende blokker av R og S.) Gjør naturlig join på hvert bucketpar separat R i S i en-pass join. Total kostnad: 3B R + 3B S disk-io 2 for å partisjonere relasjonene 1 for å gjøre join Minnekrav: M buffere kan lage M-1 buckets for hver relasjon For hvert par R i og S i må enten B Ri M-1 eller B Si M-1 Omtrent min(b R, B S ) M 2, dvs. min(b R, BS) M Hvis den minste av R i og S i ikke får plass i M-1 buffere, virker ikke algoritmen INF3100 V18 Evgenij Thorstensen 35

Naturlig Join ( ): Indeksbasert Algoritme R(X,Y) S(Y,Z) : Anta at det finnes en indeks for S på attributtene Y. Les hver blokk for R. For hvert tuppel finn tupler i S med samme joinattributtverdier ved hjelp av indeksen les de tilsvarende blokkene, gjør join på de aktuelle tuplene og output resultatet Total kostnad: B R disk-io for å lese alle R-tupler. I tillegg må vi for hvert tuppel i R lese de tilsvarende S-tuplene: Med clusterindeks på Y (så S er sortert på Y): B S / V S (Y) blokker med S-tupler for hvert R-tuppel, totalt T R B S / V S (Y). (Må runde av B S / V S (Y) oppover hvis V S (Y) er større enn B S, f.eks. når Y er kandidatnøkkel - da blir B S / V S (Y) = 1.) Hvis S ikke er sortert på Y: T S / V S (Y), totalt T R T S / V S (Y) Kostnaden domineres fullstendig av T R, vi ignorerer derfor kostnaden ved å lese R Minnekrav: 2 (en R-blokk og en S-blokk) INF3100 V18 Evgenij Thorstensen 36

Oppsummering: Kostnad og minnekrav for R S Algoritme Minnekrav Disk-IO En-pass (B S B R ) M B S + 1 B R + B S Blokkbasert nestet loop (B S B R ) M 2 B S + B R B S /(M - 1) Enkel to-pass sortering (B S B R ) M B R 5 B R + 5 B S Sort-join M (B R +B s ) 3 B R + 3 B S Hash-join (B S B R ) M B s 3 B R + 3 B S Hybrid hash-join (B S B R ) M B s (3-2M/B S )(B R + B S ) Indeks-join, clusterindeks på S.Y M 2 T R B S / V S (Y) Indeks-join, indeks på S.Y, S ikke sortert på Y M 2 T R T S / V S (Y) Zig-zag indeks-join på Y M B TR /V R (Y) +B T S /V S (Y) B R + B S INF3100 INF3100 23.3.2015 V18 Evgenij Ellen Thorstensen Munthe-Kaas 37 37

Naturlig join: eksempel Eksempel: T R = 10.000, T S = 5.000 V R (A) = 100, V S (A) = 10 4 KB blokker Postene i R og S er på 512 B (dvs. 8 poster pr. blokk) Har clusterindeks på attributt A for både R og S B S = 5.000 / 8 = 625 B R = 10.000 / 8 = 1250 INF3100 V18 Evgenij Thorstensen 38

Naturlig join: eksempel (forts.) T R = 10.000, T S = 5.000, B R = 1250, B S = 625, M = 101 Algoritme Minimum minne Disk-IO En-pass 626 1875 Blokkbasert nestet loop 2 9375 Enkel to-pass sortering 36 9375 Sort-join 44 5625 Hash-join 25 5625 Hybrid hash-join 25 5019 Indeks-join på A 2 625000 (clusterindeks på S) 62500 (clusterindeks på R) Zig-zag indeks-join på A 76 1875 INF3100 V18 Evgenij Thorstensen 39

Valg av algoritme En-passalgoritmer er bra hvis ett av argumentene (relasjonene) får plass i minnet. To-passalgoritmer må brukes hvis vi har store relasjoner. Hashbaserte algoritmer Krever mindre minne sammenlignet med sorteringstilnærminger er bare avhengig av den minste relasjonen brukes ofte. Antar omtrent lik bucketstørrelse uansett hashverdi (god hashfunksjon) i virkeligheten vil det være noe variasjon, må anta mindre bucketstørrelser. Sorteringsbaserte algoritmer Gir sortert resultat, som kan utnyttes av påfølgende operatorer. Indeksbaserte algoritmer Utmerket for seleksjon Utmerket for join hvis begge argumentene har clusterindekser. INF3100 V18 Evgenij Thorstensen 40

N passalgoritmer For virkelig store relasjoner er ikke to pass tilstrekkelig. Eksempel: B R = 1.000.000 TPMMS krever at M B R M 1000 Hvis ikke 1000 blokker er tilgjengelige, virker ikke TPMMS. Trenger flere pass gjennom datasettet. Sorteringsbaserte algoritmer: Hvis R får plass i minnet, sorter. Hvis ikke, partisjoner R i M grupper og sorter hver R i rekursivt. Flett sublistene. Total kostnad: (2k 1)B R, k er antall pass som er nødvendig Vi trenger k B R buffere, dvs. B R M k Tilsvarende kan gjøres for hashbaserte algoritmer. INF3100 V18 Evgenij Thorstensen 41

Postgres, større eksempel EXPLAIN ANALYZE SELECT * FROM tenk1 t1, tenk2 t2 WHERE t1.unique1 < 100 AND t1.unique2 = t2.unique2 ORDER BY t1.fivethous; QUERY PLAN -------------------------------------------------------------------------------------------------------------------------------------------- Sort (cost=717.34..717.59 rows=101 width=488) (actual time=7.761..7.774 rows=100 loops=1) Sort Key: t1.fivethous Sort Method: quicksort Memory: 77kB -> Hash Join (cost=230.47..713.98 rows=101 width=488) (actual time=0.711..7.427 rows=100 loops=1) Hash Cond: (t2.unique2 = t1.unique2) -> Seq Scan on tenk2 t2 (cost=0.00..445.00 rows=10000 width=244) (actual time=0.007..2.583 rows=10000 loops=1) -> Hash (cost=229.20..229.20 rows=101 width=244) (actual time=0.659..0.659 rows=100 loops=1) Buckets: 1024 Batches: 1 Memory Usage: 28kB -> Bitmap Heap Scan on tenk1 t1 (cost=5.07..229.20 rows=101 width=244) (actual time=0.080..0.526 rows=100 loops=1) Recheck Cond: (unique1 < 100) -> Bitmap Index Scan on tenk1_unique1 (cost=0.00..5.04 rows=101 width=0) (actual time=0.049..0.049 rows=100 loops=1) Index Cond: (unique1 < 100) Planning time: 0.194 ms Execution time: 8.008 ms INF3100 V18 Evgenij Thorstensen 42