Download presentation
Presentation is loading. Please wait.
1
CPSC-608 Database Systems
Fall 2018 Instructor: Jianer Chen Office: HRBB 315C Phone: Notes #27 Notes #7
2
Another Index Structure: Hash Tables
function h h(x) buckets search key x A bucket is typically a disk block (probably with overflow blocks) h(x), 0 ≤ h(x) ≤ b-1, gives an easy way to compute the bucket address (direct: address from h(x); indirect: h(x) is the index in a directory. Notes #7
3
How do we cope with growth?
Overflows and reorganizations Dynamic hashing Extensible Linear
4
How do we cope with growth?
Overflows and reorganizations Dynamic hashing Extensible Linear
5
Linear hashing Another dynamic hashing scheme
6
Linear hashing Another dynamic hashing scheme Ideas:
Use the same hash function h; Use only part of h when the hash table is smaller (use the i low order bits of h. grows b i h(x) =
7
Linear hashing Another dynamic hashing scheme Ideas:
Use the same hash function h; Use only part of h when the hash table is smaller (use the i low order bits of h. grows b i h(x) = Similar to Extensible hash
8
(c) Hash table size n grows linearly
Linear hashing Another dynamic hashing scheme Ideas: Use the same hash function h; Use only part of h when the hash table is smaller (use the i low order bits of h. grows b i h(x) = Similar to Extensible hash (c) Hash table size n grows linearly Main difference n 00..0 (|n| = i)
9
Linear hashing Another dynamic hashing scheme Ideas:
Use the same hash function h; Use only part of h when the hash table is smaller (use the i low order bits of h. grows b i h(x) = Similar to Extensible hash (c) Hash table size n grows linearly Main difference n 00..0 (|n| = i) (d) Use overflow blocks.
10
Linear hashing b h(x) = grows i Hash table size n grows linearly (n is a parameter for the hash structure b h(x) = n 00..0 (|n| = i) h(x)i i = |n|
11
Linear hashing b h(x) = grows i Hash table size n grows linearly (n is a parameter for the hash structure (backet n is the first unused bucket) b h(x) = n 00..0 (|n| = i) h(x)i i = |n|
12
Where does x go if h(x)i ≥ n?
Linear hashing b h(x) = grows i Hash table size n grows linearly (n is a parameter for the hash structure (backet n is the first unused bucket) b h(x) = n 00..0 (|n| = i) h(x)i i = |n| Where does x go if h(x)i ≥ n?
13
Where does x go if h(x)i ≥ n?
Linear hashing b h(x) = grows i Hash table size n grows linearly (n is a parameter for the hash structure (backet n is the first unused bucket) b h(x) = n 00..0 (|n| = i) h(x)i i = |n| Where does x go if h(x)i ≥ n? Put x in h(x)i – 2i-1 (< n)!! (h(x)i – 2i-1 = h(x)i with the leading bit 1 replaced with 0)
14
Linear Hashing: Searching
How Do We Search x? Linear Hashing: Searching input: a search key x \\ h is the hash function, n is the current upper bound, i = |n| m = the last i bits of h(x); IF m ≥ n THEN m = m – 2i-1; read in the disk block(s) with the address m \\ you should check overflow blocks in the address m.
15
Linear Hashing: Searching
How Do We Search x? Insert Linear Hashing: Searching Insertion input: a search key x \\ h is the hash function, n is the current upper bound, i = |n| m = the last i bits of h(x); IF m ≥ n THEN m = m – 2i-1; read in the disk block(s) with the address m \\ you should check overflow blocks in the address m.
16
Linear Hashing: Searching
How Do We Search x? Insert Linear Hashing: Searching Insertion input: a tuple t with search key x \\ h is the hash function, n is the current upper bound, i = |n| m = the last i bits of h(x); IF m ≥ n THEN m = m – 2i-1; insert t in the disk block B with the address m; \\ If B is full, you need to use an overflow block. Insert
17
Linear Hashing: Searching
How Do We Search x? Delete Linear Hashing: Searching Deletion input: a tuple t with search key x \\ h is the hash function, n is the current upper bound, i = |n| m = the last i bits of h(x); IF m ≥ n THEN m = m – 2i-1; insert t in the disk block B with the address m; \\ If B is full, you need to use an overflow block. Insert
18
Linear Hashing: Searching
How Do We Search x? Delete Linear Hashing: Searching Deletion input: a search key x \\ h is the hash function, n is the current upper bound, i = |n| m = the last i bits of h(x); IF m ≥ n THEN m = m – 2i-1; insert t in the disk block B with the address m; \\ you may need to check overflow blocks. Delete
19
How Do We Expand the Hash Table?
20
How Do We Expand the Hash Table?
When Do We Expand the Hash Table?
21
How Do We Expand the Hash Table?
When Do We Expand the Hash Table? needed space Keep track of: R = available space If R > threshold (e.g., 80%) then increase n
22
Linear Hashing: Increasing Hash Table Size
How Do We Expand the Hash Table? When Do We Expand the Hash Table? needed space Keep track of: R = available space If R > threshold (e.g., 80%) then increase n Linear Hashing: Increasing Hash Table Size input: the current upper bound n \\ h is the hash function, i = |n| read in the disk block(s) B of address n – 2i -1 ; split (properly) the tuples in B and put them in the block B and the block B’ with address n; n = n + 1;
23
Linear Hashing: Increasing Hash Table Size
How Do We Expand the Hash Table? When Do We Expand the Hash Table? needed space Keep track of: R = available space If R > threshold (e.g., 80%) then increase n Linear Hashing: Increasing Hash Table Size input: the current upper bound n \\ h is the hash function, i = |n| read in the disk block(s) B of address n – 2i -1 ; split (properly) the tuples in B and put them in the block B and the block B’ with address n; n = n + 1;
24
Linear Hashing: Increasing Hash Table Size
How Do We Expand the Hash Table? When Do We Expand the Hash Table? needed space Keep track of: R = available space If R > threshold (e.g., 80%) then increase n Linear Hashing: Increasing Hash Table Size input: the current upper bound n \\ h is the hash function, i = |n| read in the disk block(s) B of address n – 2i -1 ; split (properly) the tuples in B and put them in the block B and the block B’ with address n; n = n + 1;
25
Linear Hashing: Increasing Hash Table Size
How Do We Expand the Hash Table? When Do We Expand the Hash Table? needed space Keep track of: R = available space If R > threshold (e.g., 80%) then increase n Linear Hashing: Increasing Hash Table Size input: the current upper bound n \\ h is the hash function, i = |n| read in the disk block(s) B of address n – 2i -1 ; split (properly) the tuples in B and put them in the block B and the block B’ with address n; n = n + 1;
26
Linear Hashing: Increasing Hash Table Size
How Do We Expand the Hash Table? When Do We Expand the Hash Table? needed space Keep track of: R = available space If R > threshold (e.g., 80%) then increase n Linear Hashing: Increasing Hash Table Size input: the current upper bound n \\ h is the hash function, i = |n| read in the disk block(s) B of address n – 2i -1 ; split (properly) the tuples in B and put them in the block B and the block B’ with address n; n = n + 1;
27
Linear Hashing: Increasing Hash Table Size
How Do We Expand the Hash Table? When Do We Expand the Hash Table? needed space Keep track of: R = available space If R > threshold (e.g., 80%) then increase n Linear Hashing: Increasing Hash Table Size input: the current upper bound n \\ h is the hash function, i = |n| read in the disk block(s) B of address n – 2i -1 ; split (properly) the tuples in B and put them in the block B and the block B’ with address n; n = n + 1;
28
Linear Hashing: Increasing Hash Table Size
How Do We Expand the Hash Table? When Do We Expand the Hash Table? needed space Keep track of: R = available space If R > threshold (e.g., 80%) then increase n Linear Hashing: Increasing Hash Table Size input: the current upper bound n \\ h is the hash function, i = |n| read in the disk block(s) B of address n – 2i -1 ; split (properly) the tuples in B and put them in the block B and the block B’ with address n; n = n + 1;
29
How Do We Shrink the Hash Table?
30
How Do We Shrink the Hash Table?
When? When R is smaller than a threshold (e.g., 50%)
31
Linear Hashing: Decreasing Hash Table Size
How Do We Shrink the Hash Table? When? When R is smaller than a threshold (e.g., 50%) Linear Hashing: Decreasing Hash Table Size input: the current upper bound n \\ h is the hash function, i = |n| n = n − 1; move the tuples in the block(s) of address n to the block(s) of address n – 2i -1 (here i is the length of the new n).
32
Linear Hashing: Decreasing Hash Table Size
How Do We Shrink the Hash Table? When? When R is smaller than a threshold (e.g., 50%) Linear Hashing: Decreasing Hash Table Size input: the current upper bound n \\ h is the hash function, i = |n| n = n − 1; move the tuples in the block(s) of address n to the block(s) of address n – 2i -1 (here i is the length of the new n).
33
Linear Hashing: Decreasing Hash Table Size
How Do We Shrink the Hash Table? When? When R is smaller than a threshold (e.g., 50%) Linear Hashing: Decreasing Hash Table Size input: the current upper bound n \\ h is the hash function, i = |n| n = n − 1; move the tuples in the block(s) of address n to the block(s) of address n – 2i -1 (here i is the length of the new n).
34
Linear Hashing: Decreasing Hash Table Size
How Do We Shrink the Hash Table? When? When R is smaller than a threshold (e.g., 50%) Linear Hashing: Decreasing Hash Table Size input: the current upper bound n \\ h is the hash function, i = |n| n = n − 1; move the tuples in the block(s) of address n to the block(s) of address n – 2i -1 (here i is the length of the new n).
35
Linear Hashing: Decreasing Hash Table Size
How Do We Shrink the Hash Table? When? When R is smaller than a threshold (e.g., 50%) Linear Hashing: Decreasing Hash Table Size input: the current upper bound n \\ h is the hash function, i = |n| n = n − 1; move the tuples in the block(s) of address n to the block(s) of address n – 2i -1 (here i is the length of the new n).
36
Linear Hashing: Decreasing Hash Table Size
How Do We Shrink the Hash Table? When? When R is smaller than a threshold (e.g., 50%) Linear Hashing: Decreasing Hash Table Size input: the current upper bound n \\ h is the hash function, i = |n| n = n − 1; move the tuples in the block(s) of address n to the block(s) of address n – 2i -1 (here i is the length of the new n).
37
Linear Hashing: General framework
00…00 00…01 x h h(x) i h(x)i . b i no tuples 1*…** = n i grow linearly buckets
38
Example b=4 bits, 2 keys/bucket
Future growth buckets 0000 0101 1010 1111
39
Example b=4 bits, 2 keys/bucket n = 10 (1 + the largest index of the used buckets)
future growth buckets 0000 0101 1010 1111 n =10
40
Example b=4 bits, 2 keys/bucket n = 10 (1 + the largest index of the used buckets) i = |n| = 2 (# used bits) Future growth buckets 0000 0101 1010 1111 n =10
41
Example b=4 bits, 2 keys/bucket n = 10 (1 + the largest index of the used buckets) i = |n| = 2 (# used bits) Future growth buckets 0000 0101 1010 1111 n =10 Rules: If h(x)i < n, then look at bucket h(x)i
42
Example b=4 bits, 2 keys/bucket n = 10 (1 + the largest index of the used buckets) i = |n| = 2 (# used bits) Future growth buckets 0000 0101 1010 1111 n =10 Rules: If h(x)i < n, then look at bucket h(x)i If h(x)i ≥ n, then look at bucket h(x)i − 2i -1 (i.e., replacing the leading bit 1 of h(x)i by 0)
43
Insertion: b=4 bits, 2 keys/bucket, n=10, i=2
1101 (can have overflow chains!) Future growth buckets 0000 0101 1010 1111 n =10 Rules: If h(x)i < n, then look at bucket h(x)i If h(x)i ≥ n, then look at bucket h(x)i − 2i -1 (i.e., replacing the leading bit 1 of h(x)i by 0)
44
Increase size n: b=4 bits, n=10, i=2
0000 0101 1010 1111 n = 10
45
Increase size n: b=4 bits, n=10, i=2
0000 0101 1010 1111 n = 10
46
Increase size n: b=4 bits, n=10, i=2
0000 0101 1010 1111 n = 10
47
Increase size n: b=4 bits, n=11, i=2
0000 0101 1010 1010 1111 n = 10
48
Increase size n: b=4 bits, n=11, i=2
Future growth buckets 0000 0101 1010 1111 n =11 10
49
Insert: b=4 bits, n=11, i=2 insert 1101 1101 0000 0101 1010 1111
Future growth buckets 0000 0101 1010 1111 n =11 10
50
Increase size n: b=4 bits, n=11, i=2
1101 0000 0101 1010 1111 n =11 10
51
Increase size n: b=4 bits, n=11, i=2
1101 0000 0101 1010 1111 n =11 10
52
Increase size n: b=4 bits, n=11, i=2
1101 0000 0101 1010 1111 n =11 10
53
Increase size n: b=4 bits, n=100, i=3
1101 0000 0101 1010 1111 1111 n =11 10
54
Increase size n: b=4 bits, n=100, i=3
1101 0000 0101 1010 1111 10 n =100
55
Increase size n: b=4 bits, n=100, i=3
0101 0000 0101 1010 1111 1101 10 n =100
56
Linear Hashing Summary + + Can handle growing files
- with less wasted space - with no full reorganizations No indirection like extensible hashing + +
57
Linear Hashing Summary + + ‒ Can handle growing files
- with less wasted space - with no full reorganizations No indirection like extensible hashing + + overflow chains ‒
58
Example: BAD CASE Very full Very empty Need to move n here…
Would waste space…
59
Summary Hashing - How it works - Dynamic hashing - Extensible - Linear
60
DBMS graduate database in tables (relations) lock table DDL language
administrator DDL complier lock table DDL language file manager logging & recovery concurrency control transaction manager database programmer index/file manager buffer manager DML (query) language query execution engine DML complier main memory buffers secondary storage (disks) DBMS graduate database
61
Next Algorithms implementing the relational algebraic operations:
Projection and selection Set and bag operations Join operations Grouping, duplicate elimination, sorting
62
Algorithms Implementing Relational Algebraic Operations
Projection and selection π, σ Set/bag operations US, ∩S, −S, UB, ∩B, −B Join operations Extended operations γ, δ, τ, table-scan × C ,
63
DBMS graduate database in tables (relations) lock table DDL language
administrator DDL complier lock table DDL language file manager logging & recovery concurrency control transaction manager database programmer index/file manager buffer manager DML (query) language query execution engine DML complier main memory buffers secondary storage (disks) DBMS graduate database
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.