85
Intro to Database Systems 15-445/15-645 Fall 2019 Andy Pavlo Computer Science Carnegie Mellon University AP 06 Hash Tables

06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

  • Upload
    others

  • View
    0

  • Download
    0

Embed Size (px)

Citation preview

Page 1: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

Intro to Database Systems

15-445/15-645

Fall 2019

Andy PavloComputer Science Carnegie Mellon UniversityAP

06 Hash Tables

Page 2: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

ADMINISTRIVIA

Project #1 is due Fri Sept 27th @ 11:59pm

Homework #2 is due Mon Sept 30th @ 11:59pm

2

Page 3: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

Query Planning

Operator Execution

Access Methods

Buffer Pool Manager

Disk Manager

COURSE STATUS

We are now going to talk about how to support the DBMS's execution engine to read/write data from pages.

Two types of data structures:→ Hash Tables→ Trees

3

Page 4: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

DATA STRUCTURES

Internal Meta-data

Core Data Storage

Temporary Data Structures

Table Indexes

4

Page 5: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

DESIGN DECISIONS

Data Organization→ How we layout data structure in memory/pages and what

information to store to support efficient access.

Concurrency→ How to enable multiple threads to access the data

structure at the same time without causing problems.

5

Page 6: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

HASH TABLES

A hash table implements an unordered associative array that maps keys to values.

It uses a hash function to compute an offset into the array for a given key, from which the desired value can be found.

Space Complexity: O(n)Operation Complexity:→ Average: O(1)→ Worst: O(n)

6

Money cares about constants!

Page 7: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

STATIC HASH TABLE

Allocate a giant array that has one slot for every element you need to store.

To find an entry, mod the key by the number of elements to find the offset in the array.

7

hash(key)

0

1

2

n

abc

def

xyz

Ø

Page 8: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

STATIC HASH TABLE

Allocate a giant array that has one slot for every element you need to store.

To find an entry, mod the key by the number of elements to find the offset in the array.

7

hash(key)

0

1

2

n

abcdefghi

defghijk

xyz123

Page 9: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

ASSUMPTIONS

You know the number of elements ahead of time.

Each key is unique.

Perfect hash function.→ If key1≠key2, then

hash(key1)≠hash(key2)

8

hash(key)

0

1

2

n

abcdefghi

defghijk

xyz123

Page 10: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

HASH TABLE

Design Decision #1: Hash Function→ How to map a large key space into a smaller domain.→ Trade-off between being fast vs. collision rate.

Design Decision #2: Hashing Scheme→ How to handle key collisions after hashing.→ Trade-off between allocating a large hash table vs.

additional instructions to find/insert keys.

9

Page 11: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

TODAY'S AGENDA

Hash Functions

Static Hashing Schemes

Dynamic Hashing Schemes

10

Page 12: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

HASH FUNCTIONS

For any input key, return an integer representation of that key.

We do not want to use a cryptographic hash function for DBMS hash tables.

We want something that is fast and has a low collision rate.

11

Page 13: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

HASH FUNCTIONS

CRC-64 (1975)→ Used in networking for error detection.

MurmurHash (2008)→ Designed to a fast, general purpose hash function.

Google CityHash (2011)→ Designed to be faster for short keys (<64 bytes).

Facebook XXHash (2012)→ From the creator of zstd compression.

Google FarmHash (2014)→ Newer version of CityHash with better collision rates.

12

Page 14: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

HASH FUNCTION BENCHMARK

13

0

1000

2000

3000

4000

1 2 3 4 5 6 7 8

Thr

ough

put (

MB

/sec

)

Key Size (bytes)

crc64 std::hash MurmurHash3 CityHash FarmHash XXHash3

Source: Fredrik Widlund

Intel Core i7-8700K @ 3.70GHz

Page 15: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

HASH FUNCTION BENCHMARK

14

0

7000

14000

21000

28000

1 51 101 151 201 251

Thr

ough

put (

MB

/sec

)

Key Size (bytes)

crc64 std::hash MurmurHash3 CityHash FarmHash XXHash3

Source: Fredrik Widlund

Intel Core i7-8700K @ 3.70GHz

32

64128

192

Page 16: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

STATIC HASHING SCHEMES

Approach #1: Linear Probe Hashing

Approach #2: Robin Hood Hashing

Approach #3: Cuckoo Hashing

15

Page 17: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR PROBE HASHING

Single giant table of slots.

Resolve collisions by linearly searching for the next free slot in the table.→ To determine whether an element is present, hash to a

location in the index and scan for it.→ Have to store the key in the index to know when to stop

scanning.→ Insertions and deletions are generalizations of lookups.

16

Page 18: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

<key>|<value>

LINEAR PROBE HASHING

17

ABCD

hash(key)

| valA

EF

Page 19: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR PROBE HASHING

17

ABCD

hash(key)

| valA

| valB

EF

Page 20: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR PROBE HASHING

17

ABCD

hash(key)

| valA

| valB

| valC

EF

Page 21: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR PROBE HASHING

17

ABCD

hash(key)

| valA

| valB

| valC

| valDEF

Page 22: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR PROBE HASHING

17

ABCD

hash(key)

| valA

| valB

| valC

| valDE

| valEF

Page 23: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR PROBE HASHING

17

ABCD

hash(key)

| valA

| valB

| valC

| valDE

| valEF

| valF

Page 24: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR PROBE HASHING DELETES

18

ABCD

hash(key)

| valA

| valB

| valC

EF

| valD

| valE

| valF

Delete

Page 25: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR PROBE HASHING DELETES

18

ABCD

hash(key)

| valA

| valB

EF

| valD

| valE

| valF

Delete

Page 26: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR PROBE HASHING DELETES

18

ABCD

hash(key)

| valA

| valB

EF

| valD

| valE

| valF

Find

Page 27: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR PROBE HASHING DELETES

Approach #1: Tombstone

18

ABCD

hash(key)

| valA

| valB

EF

| valD

| valE

| valF

Find

Page 28: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR PROBE HASHING DELETES

Approach #1: Tombstone

Approach #2: Movement

18

ABCD

hash(key)

| valA

| valB

EF

| valD

| valE

| valF

Find

Page 29: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR PROBE HASHING DELETES

Approach #1: Tombstone

Approach #2: Movement

18

ABCD

hash(key)

| valA

| valB

EF

| valD

| valE

| valF

Find

Page 30: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR PROBE HASHING DELETES

Approach #1: Tombstone

Approach #2: Movement

18

ABCD

hash(key)

| valA

| valB

EF

| valD

| valE

| valF

Find

Page 31: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR PROBE HASHING DELETES

Approach #1: Tombstone

Approach #2: Movement

18

ABCD

hash(key)

| valA

| valB

EF

| valD

| valE

| valF

Find

Page 32: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

NON-UNIQUE KEYS

Choice #1: Separate Linked List→ Store values in separate storage area for

each key.

Choice #2: Redundant Keys→ Store duplicate keys entries together in

the hash table.

19

XYZ

ABC

value1value2value3

Value Lists

value1value2

XYZ|value1

ABC|value1

XYZ|value2

XYZ|value3

ABC|value2

Page 33: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

ROBIN HOOD HASHING

Variant of linear probe hashing that steals slots from "rich" keys and give them to "poor" keys.→ Each key tracks the number of positions they are from

where its optimal position in the table.→ On insert, a key takes the slot of another key if the first

key is farther away from its optimal position than the second key.

20

Page 34: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

ROBIN HOOD HASHING

21

ABCD

hash(key)

| val [0]A

E

# of "Jumps" From First Position

F

Page 35: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

ROBIN HOOD HASHING

21

ABCD

hash(key)

| val [0]A

| val [0]B

EF

Page 36: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

ROBIN HOOD HASHING

21

ABCD

hash(key)

| val [0]A

| val [0]B

| val [1]C

EF

A[0] == C[0]

Page 37: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

ROBIN HOOD HASHING

21

ABCD

hash(key)

| val [0]A

| val [0]B

| val [1]C

| val [1]DEF

C[1] > D[0]

Page 38: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

ROBIN HOOD HASHING

21

ABCD

hash(key)

| val [0]A

| val [0]B

| val [1]C

| val [1]DE

A[0] == E[0]

C[1] == E[1]

D[1] < E[2]

F

Page 39: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

ROBIN HOOD HASHING

21

ABCD

hash(key)

| val [0]A

| val [0]B

| val [1]C

E | val [2]E

A[0] == E[0]

C[1] == E[1]

D[1] < E[2]

F | val [2]D

Page 40: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

ROBIN HOOD HASHING

21

ABCD

hash(key)

| val [0]A

| val [0]B

| val [1]C

E | val [2]E

F | val [2]D

| val [1]F

D[2] > F[0]

Page 41: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

CUCKOO HASHING

Use multiple hash tables with different hash function seeds.→ On insert, check every table and pick anyone that has a

free slot.→ If no table has a free slot, evict the element from one of

them and then re-hash it find a new location.

Look-ups and deletions are always O(1) because only one location per hash table is checked.

22

Page 42: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

CUCKOO HASHING

23

Hash Table #1

Hash Table #2

Insert Ahash1(A) hash2(A)

Page 43: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

CUCKOO HASHING

23

Hash Table #1

Hash Table #2

Insert Ahash1(A) hash2(A)

A|val

Page 44: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

CUCKOO HASHING

23

Hash Table #1

Hash Table #2

Insert Ahash1(A) hash2(A)

Insert Bhash1(B) hash2(B)

A|val

Page 45: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

CUCKOO HASHING

23

Hash Table #1

Hash Table #2

Insert Ahash1(A) hash2(A)

Insert Bhash1(B) hash2(B)

B|valA|val

Page 46: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

CUCKOO HASHING

23

Hash Table #1

Hash Table #2

Insert Ahash1(A) hash2(A)

Insert Bhash1(B) hash2(B)

Insert Chash1(C) hash2(C)

B|valA|val

Page 47: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

CUCKOO HASHING

23

Hash Table #1

Hash Table #2

Insert Ahash1(A) hash2(A)

Insert Bhash1(B) hash2(B)

Insert Chash1(C) hash2(C)

A|valC|val

Page 48: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

CUCKOO HASHING

23

Hash Table #1

Hash Table #2

Insert Ahash1(A) hash2(A)

Insert Bhash1(B) hash2(B)

Insert Chash1(C) hash2(C)

hash1(B)

C|valB|val

Page 49: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

CUCKOO HASHING

23

Hash Table #1

Hash Table #2

Insert Ahash1(A) hash2(A)

Insert Bhash1(B) hash2(B)

Insert Chash1(C) hash2(C)

hash1(B)hash2(A)

A|val

C|valB|val

Page 50: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

OBSERVATION

The previous hash tables require the DBMS to know the number of elements it wants to store.→ Otherwise it has rebuild the table if it needs to

grow/shrink in size.

Dynamic hash tables resize themselves on demand.→ Chained Hashing→ Extendible Hashing→ Linear Hashing

24

Page 51: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

CHAINED HASHING

Maintain a linked list of buckets for each slot in the hash table.

Resolve collisions by placing all elements with the same hash key into the same bucket.→ To determine whether an element is present, hash to its

bucket and scan for it.→ Insertions and deletions are generalizations of lookups.

25

Page 52: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

CHAINED HASHING

26

Ø

hash(key)

⋮ ⋮

Buckets

Page 53: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

CHAINED HASHING

26

Ø

hash(key)

⋮ ⋮

Buckets

Page 54: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

EXTENDIBLE HASHING

Chained-hashing approach where we split buckets instead of letting the linked list grow forever.

Multiple slot locations can point to the same bucket chain.

Reshuffling bucket entries on split and increase the number of bits to examine.→ Data movement is localized to just the split chain.

28

Page 55: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

EXTENDIBLE HASHING

29

global 2

0 1…

0 0…

1 0…

1 1…

local

local

local

00010…

01110…1

10101…

10011…2

11010… 2

Page 56: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

EXTENDIBLE HASHING

29

global 2

0 1…

0 0…

1 0…

1 1…

local

local

local

00010…

01110…1

10101…

10011…2

11010… 2

hash(A) = 01110…Find A

Page 57: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

EXTENDIBLE HASHING

29

global 2

0 1…

0 0…

1 0…

1 1…

local

local

local

00010…

01110…1

10101…

10011…2

11010… 2

hash(A) = 01110…Find A

hash(B) = 10111…Insert B

10111…

Page 58: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

EXTENDIBLE HASHING

29

global 2

0 1…

0 0…

1 0…

1 1…

local

local

local

00010…

01110…1

10101…

10011…2

11010… 2

hash(A) = 01110…Find A

hash(B) = 10111…Insert B

hash(C) = 10100…Insert C

10111…

Page 59: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

EXTENDIBLE HASHING

29

global 2

0 1…

0 0…

1 0…

1 1…

local

local

local

00010…

01110…1

10101…

10011…2

11010… 2

hash(A) = 01110…Find A

hash(B) = 10111…Insert B

hash(C) = 10100…Insert C

10111…

Page 60: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

EXTENDIBLE HASHING

29

global 2

0 1…

0 0…

1 0…

1 1…

local

local

local

00010…

01110…1

10101…

10011…2

11010… 2

hash(A) = 01110…Find A

hash(B) = 10111…Insert B

hash(C) = 10100…Insert C

3

10111…

Page 61: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

EXTENDIBLE HASHING

29

global 2 local

local

local

00010…

01110…1

10101…

10011…2

11010… 2

hash(A) = 01110…Find A

hash(B) = 10111…Insert B

hash(C) = 10100…Insert C

0 10…

0 00…

1 00…

1 10…

0 11…

0 01…

1 01…

1 11…

3

10111…

Page 62: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

EXTENDIBLE HASHING

29

global 2 00010…

01110…1

11010… 2

hash(A) = 01110…Find A

hash(B) = 10111…Insert B

hash(C) = 10100…Insert C

0 10…

0 00…

1 00…

1 10…

0 11…

0 01…

1 01…

1 11…

3

10011…3

10101…

10111…

3

Page 63: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

EXTENDIBLE HASHING

29

global 2 00010…

01110…1

11010… 2

hash(A) = 01110…Find A

hash(B) = 10111…Insert B

hash(C) = 10100…Insert C

0 10…

0 00…

1 00…

1 10…

0 11…

0 01…

1 01…

1 11…

3

10011…3

10101…

10111…

310100…

Page 64: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR HASHING

The hash table maintains a pointer that tracks the next bucket to split.→ When any bucket overflows, split the bucket at the

pointer location.

Use multiple hashes to find the right bucket for a given key.

Can use different overflow criterion:→ Space Utilization→ Average Length of Overflow Chains

30

Page 65: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR HASHING

31

1

0

2

3

8

5

9

13

6

7

11

20

Page 66: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR HASHING

31

1

0

2

3

8

5

9

13

6

7

11

Split Pointer

hash1(key) = key % n

20

Page 67: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR HASHING

31

1

0

2

3

8

hash1(6) = 6 % 4 = 2Find 6

5

9

13

6

7

11

Split Pointer

hash1(key) = key % n

20

Page 68: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR HASHING

31

1

0

2

3

8

hash1(6) = 6 % 4 = 2Find 6

5

9

13

6

7

11

Split Pointer

hash1(key) = key % n

hash1(17) = 17 % 4 = 1Insert 17

20

Page 69: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR HASHING

31

1

0

2

3

8

hash1(6) = 6 % 4 = 2Find 6

5

9

13

6

7

11

Split Pointer

hash1(key) = key % n

hash1(17) = 17 % 4 = 1Insert 1717

20

Overflow!

Page 70: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR HASHING

31

1

0

2

3

8

hash1(6) = 6 % 4 = 2Find 6

5

9

13

6

7

11

Split Pointer

hash1(key) = key % n

hash1(17) = 17 % 4 = 1Insert 1717

4

hash2(key) = key % 2n

20

Overflow!

Page 71: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR HASHING

31

1

0

2

3

8

hash1(6) = 6 % 4 = 2Find 6

5

9

13

6

7

11

Split Pointer

hash1(key) = key % n

hash1(17) = 17 % 4 = 1Insert 1717

4

20hash2(key) = key % 2n

Page 72: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR HASHING

31

1

0

2

3

8

hash1(6) = 6 % 4 = 2Find 6

5

9

13

6

7

11

Split Pointer

hash1(key) = key % n

hash1(17) = 17 % 4 = 1Insert 17

hash1(20) = 20 % 4 = 0Find 20

17

4

20hash2(key) = key % 2n

Page 73: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR HASHING

31

1

0

2

3

8

hash1(6) = 6 % 4 = 2Find 6

5

9

13

6

7

11

Split Pointer

hash1(key) = key % n

hash1(17) = 17 % 4 = 1Insert 17

hash1(20) = 20 % 4 = 0Find 20

17

4

20hash2(key) = key % 2n

hash2(20) = 20 % 8 = 4

Page 74: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR HASHING

31

1

0

2

3

8

hash1(6) = 6 % 4 = 2Find 6

5

9

13

6

7

11

Split Pointer

hash1(key) = key % n

hash1(17) = 17 % 4 = 1Insert 17

hash1(20) = 20 % 4 = 0Find 20

17

4

20hash2(key) = key % 2n

hash2(20) = 20 % 8 = 4

hash1(9) = 9 % 4 = 1Find 9

Page 75: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR HASHING

31

1

0

2

3

8

hash1(6) = 6 % 4 = 2Find 6

5

9

13

6

7

11

Split Pointer

hash1(key) = key % n

hash1(17) = 17 % 4 = 1Insert 17

hash1(20) = 20 % 4 = 0Find 20

17

4

20hash2(key) = key % 2n

hash2(20) = 20 % 8 = 4

hash1(9) = 9 % 4 = 1Find 9

Page 76: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR HASHING

Splitting buckets based on the split pointer will eventually get to all overflowed buckets.→ When the pointer reaches the last slot, delete the first

hash function and move back to beginning.

The pointer can also move backwards when buckets are empty.

32

Page 77: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR HASHING DELETES

33

1

0

2

3

8

5

9

13

6

7

11

Split Pointer

hash1(key) = key % n

17

4

20hash2(key) = key % 2n

hash1(20) = 20 % 4 = 0Delete 20

Page 78: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR HASHING DELETES

33

1

0

2

3

8

5

9

13

6

7

11

Split Pointer

hash1(key) = key % n

17

4

20hash2(key) = key % 2n

hash1(20) = 20 % 4 = 0Delete 20

hash2(20) = 20 % 8 = 4

Page 79: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR HASHING DELETES

33

1

0

2

3

8

5

9

13

6

7

11

Split Pointer

hash1(key) = key % n

17

4

20hash2(key) = key % 2n

hash1(20) = 20 % 4 = 0Delete 20

hash2(20) = 20 % 8 = 4

Page 80: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR HASHING DELETES

33

1

0

2

3

8

5

9

13

6

7

11

Split Pointer

hash1(key) = key % n

17

4

hash2(key) = key % 2n

hash1(20) = 20 % 4 = 0Delete 20

hash2(20) = 20 % 8 = 4

Page 81: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR HASHING DELETES

33

1

0

2

3

8

5

9

13

6

7

11

Split Pointer

hash1(key) = key % n

17

4

hash2(key) = key % 2n

hash1(20) = 20 % 4 = 0Delete 20

hash2(20) = 20 % 8 = 4

Page 82: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR HASHING DELETES

33

1

0

2

3

8

5

9

13

6

7

11

Split Pointer

hash1(key) = key % n

17

hash1(20) = 20 % 4 = 0Delete 20

hash2(20) = 20 % 8 = 4

Page 83: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

LINEAR HASHING DELETES

33

1

0

2

3

8

5

9

13

6

7

11

Split Pointer

hash1(key) = key % n

17

hash1(20) = 20 % 4 = 0Delete 20

hash2(20) = 20 % 8 = 4

hash1(21) = 21 % 4 = 1Insert 21

Overflow!

21

Page 84: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

CONCLUSION

Fast data structures that support O(1) look-ups that are used all throughout the DBMS internals.→ Trade-off between speed and flexibility.

Hash tables are usually not what you want to use for a table index…

34

Page 85: 06 Hash Tables - 15445.courses.cs.cmu.edu · Use multiple hash tables with different hash function seeds. →On insert, check every table and pick anyone that has a free slot. →If

CMU 15-445/645 (Fall 2019)

NEXT CL ASS

B+Trees→ aka "The Greatest Data Structure of All Time!"

35