CS 245: Database System Principles

Slides:



Advertisements
Similar presentations
External Memory Hashing. Model of Computation Data stored on disk(s) Minimum transfer unit: a page = b bytes or B records (or block) N records -> N/B.
Advertisements

CS4432: Database Systems II Hash Indexing 1. Hash-Based Indexes Adaptation of main memory hash tables Support equality searches No range searches 2.
©Silberschatz, Korth and Sudarshan12.1Database System Concepts Chapter 12: Part C Part A:  Index Definition in SQL  Ordered Indices  Index Sequential.
Database Management Systems 3ed, R. Ramakrishnan and J. Gehrke1 Hash-Based Indexes Chapter 11.
Database Management Systems 3ed, R. Ramakrishnan and J. Gehrke1 Hash-Based Indexes Chapter 11.
DBMS 2001Notes 4.2: Hashing1 Principles of Database Management Systems 4.2: Hashing Techniques Pekka Kilpeläinen (after Stanford CS245 slide originals.
Hashing and Indexing John Ortiz.
CS 245Notes 51 CS 245: Database System Principles Hector Garcia-Molina Notes 5: Hashing and More.
©Silberschatz, Korth and Sudarshan12.1Database System Concepts Chapter 12: Indexing and Hashing Basic Concepts Ordered Indices B+-Tree Index Files B-Tree.
Index tuning Hash Index. overview Introduction Hash-based indexes are best for equality selections. –Can efficiently support index nested joins –Cannot.
CS 4432lecture #11 - indexing & hashing1 CS4432: Database Systems II Lecture #11 Professor Elke A. Rundensteiner.
1 Hash-Based Indexes Yanlei Diao UMass Amherst Feb 22, 2006 Slides Courtesy of R. Ramakrishnan and J. Gehrke.
1 Indexing and Hashing Indexing and Hashing Basic Concepts Dense and Sparse Indices B+Trees, B-trees Dynamic Hashing Comparison of Ordered Indexing and.
1 Hash-Based Indexes Chapter Introduction  Hash-based indexes are best for equality selections. Cannot support range searches.  Static and dynamic.
CPSC-608 Database Systems Fall 2010 Instructor: Jianer Chen Office: HRBB 315C Phone: Notes #8.
CPSC-608 Database Systems Fall 2011 Instructor: Jianer Chen Office: HRBB 315C Phone: Notes #11.
CPSC-608 Database Systems Fall 2009 Instructor: Jianer Chen Office: HRBB 309B Phone: Notes #9.
1 Hash-Based Indexes Chapter Introduction : Hash-based Indexes  Best for equality selections.  Cannot support range searches.  Static and dynamic.
CPSC-608 Database Systems Fall 2008 Instructor: Jianer Chen Office: HRBB 309B Phone: Notes #8.
CS 245Notes 51 CS 245: Database System Principles Hector Garcia-Molina Notes 5: Hashing and More.
CS 4432lecture #10 - indexing & hashing1 CS4432: Database Systems II Lecture #10 Professor Elke A. Rundensteiner.
CS 277 – Spring 2002Notes 51 CS 277: Database System Implementation Arthur Keller Notes 5: Hashing and More.
CPSC-608 Database Systems Fall 2011 Instructor: Jianer Chen Office: HRBB 315C Phone: Notes #12.
CS CS4432: Database Systems II. CS Index definition in SQL Create index name on rel (attr) (Check online for index definitions in SQL) Drop.
CPSC-608 Database Systems Fall 2008 Instructor: Jianer Chen Office: HRBB 309B Phone: Notes #9.
1 Chapter 12: Indexing and Hashing Indexing Indexing Basic Concepts Basic Concepts Ordered Indices Ordered Indices B+-Tree Index Files B+-Tree Index Files.
1 CS232A: Database System Principles INDEXING. 2 Given condition on attribute find qualified records Attr = value Condition may also be Attr>value Attr>=value.
CS 4432query processing1 CS4432: Database Systems II Lecture #11 Professor Elke A. Rundensteiner.
CS 245Notes 51 CS 245: Database System Principles Hector Garcia-Molina Notes 5: Hashing and More.
CS 245Notes 51 CS 245: Database System Principles Hector Garcia-Molina Notes 5: Hashing and More.
Introduction to Database, Fall 2004/Melikyan1 Hash-Based Indexes Chapter 10.
Database Management Systems 3ed, R. Ramakrishnan and J. Gehrke1 Indexed Sequential Access Method.
Database Management Systems, R. Ramakrishnan and J. Gehrke1 Hash-Based Indexes Chapter 10.
Hash-Based Indexes. Introduction uAs for any index, 3 alternatives for data entries k*: w Data record with key value k w w Choice orthogonal to the indexing.
CS4432: Database Systems II
1 Ullman et al. : Database System Principles Notes 5: Hashing and More.
CPSC 8620Notes 61 CPSC 8620: Database Management System Design Notes 6: Hashing and More.
Chapter 5. Multidimensional Indexes
Access Structures COMP3211 Advanced Databases Dr Nicholas Gibbins
COMP3017 Advanced Databases
CS 245: Database System Principles
Advanced Database Systems: DBS CB, 2nd Edition
Dynamic Hashing (Chapter 12)
CS232A: Database System Principles INDEXING
Hash-Based Indexes Chapter 11
CPSC-608 Database Systems
External Memory Hashing
Introduction to Database Systems
Yan Huang - CSCI5330 Database Implementation – Access Methods
External Memory Hashing
CS222: Principles of Data Management Notes #8 Static Hashing, Extendible Hashing, Linear Hashing Instructor: Chen Li.
Hash-Based Indexes Chapter 10
External Memory Hashing
CS222P: Principles of Data Management Notes #8 Static Hashing, Extendible Hashing, Linear Hashing Instructor: Chen Li.
CS 245: Database System Principles
Hash-Based Indexes Chapter 11
Index tuning Hash Index.
Database Systems (資料庫系統)
Database Design and Programming
Module 12a: Dynamic Hashing
Chapter 11: Indexing and Hashing
CPSC-608 Database Systems
CPSC-608 Database Systems
Index tuning Hash Index.
Hash-Based Indexes Chapter 11
Chapter 11 Instructor: Xin Zhang
CS222/CS122C: Principles of Data Management UCI, Fall 2018 Notes #07 Static Hashing, Extendible Hashing, Linear Hashing Instructor: Chen Li.
CS4432: Database Systems II
Index Structures Chapter 13 of GUW September 16, 2019
Presentation transcript:

CS 245: Database System Principles Notes 5: Hashing and More Hector Garcia-Molina CS 245 Notes 5

Hashing key  h(key) <key> Buckets (typically 1 disk block) . CS 245 Notes 5

Two alternatives . records (1) key  h(key) . CS 245 Notes 5

Two alternatives record (2) key  h(key) key 1 Index CS 245 Notes 5

Alt (2) for “secondary” search key Two alternatives record (2) key  h(key) key 1 Index Alt (2) for “secondary” search key CS 245 Notes 5

Example hash function Key = ‘x1 x2 … xn’ n byte character string Have b buckets h: add x1 + x2 + ….. xn compute sum modulo b CS 245 Notes 5

 This may not be best function …  Read Knuth Vol. 3 if you really need to select a good function. CS 245 Notes 5

 This may not be best function …  Read Knuth Vol. 3 if you really need to select a good function. Good hash  Expected number of function: keys/bucket is the same for all buckets CS 245 Notes 5

Within a bucket: Do we keep keys sorted? Yes, if CPU time critical & Inserts/Deletes not too frequent CS 245 Notes 5

Next: example to illustrate inserts, overflows, deletes h(K) CS 245 Notes 5

EXAMPLE 2 records/bucket 1 2 3 INSERT: h(a) = 1 h(b) = 2 h(c) = 1 h(d) = 0 CS 245 Notes 5

EXAMPLE 2 records/bucket 1 2 3 INSERT: h(a) = 1 h(b) = 2 h(c) = 1 h(d) = 0 d a c b h(e) = 1 CS 245 Notes 5

EXAMPLE 2 records/bucket 1 2 3 INSERT: h(a) = 1 h(b) = 2 h(c) = 1 h(d) = 0 d a c b e h(e) = 1 CS 245 Notes 5

EXAMPLE: deletion Delete: e f 1 2 3 a b d c e f g CS 245 Notes 5

EXAMPLE: deletion Delete: e f c a b d c e f g 1 2 3 maybe move “g” up 1 2 3 a b d c c e maybe move “g” up f g CS 245 Notes 5

EXAMPLE: deletion Delete: e f c a b d c d e f g 1 2 3 maybe move 1 2 3 a d b d c c e maybe move “g” up f g CS 245 Notes 5

Rule of thumb: Try to keep space utilization between 50% and 80% Utilization = # keys used total # keys that fit CS 245 Notes 5

Rule of thumb: Try to keep space utilization between 50% and 80% Utilization = # keys used total # keys that fit If < 50%, wasting space If > 80%, overflows significant depends on how good hash function is & on # keys/bucket CS 245 Notes 5

How do we cope with growth? Overflows and reorganizations Dynamic hashing CS 245 Notes 5

How do we cope with growth? Overflows and reorganizations Dynamic hashing Extensible Linear CS 245 Notes 5

Extensible hashing: two ideas (a) Use i of b bits output by hash function b h(K)  use i  grows over time…. 00110101 CS 245 Notes 5

(b) Use directory h(K)[i ] to bucket . . CS 245 Notes 5

Example: h(k) is 4 bits; 2 keys/bucket 1 i = 0001 1 1 1001 1100 Insert 1010 CS 245 Notes 5

Example: h(k) is 4 bits; 2 keys/bucket 1 i = 0001 1 1 1001 1 1100 1010 1100 Insert 1010 CS 245 Notes 5

Example: h(k) is 4 bits; 2 keys/bucket New directory 2 00 01 10 11 i = 1 i = 0001 1 1 1001 1 1100 1010 1100 Insert 1010 CS 245 Notes 5

Example continued i = 2 1 0001 2 1001 1010 Insert: 0111 2 0000 1100 00 CS 245 Notes 5

Example continued 0000 i = 2 0001 1 0001 0111 0111 2 1001 1010 Insert: 1100 CS 245 Notes 5

Example continued 2 0000 0111 0001 i = 2 00 01 10 11 1 0001 0111 2 1001 1010 Insert: 0111 0000 2 1100 CS 245 Notes 5

Example continued 2 0000 0001 i = 2 2 0111 2 1001 1010 Insert: 1001 2 1100 CS 245 Notes 5

Example continued 0000 2 i = 0001 2 00 01 10 11 0111 2 1001 1010 2 1001 1010 Insert: 1001 2 1100 CS 245 Notes 5

Example continued i = 3 2 0000 0001 i = 2 2 0111 1001 1010 2 1001 1010 110 111 3 i = 0000 2 i = 0001 2 00 01 10 11 0111 2 1001 1010 2 1001 1010 Insert: 1001 2 1100 CS 245 Notes 5

Extensible hashing: deletion No merging of blocks Merge blocks and cut directory if possible (Reverse insert procedure) CS 245 Notes 5

Deletion example: Run thru insert example in reverse! CS 245 Notes 5

Note: Still need overflow chains Example: many records with duplicate keys if we split: insert 1100 2 1 1101 1100 2 1100 1100 CS 245 Notes 5

Solution: overflow chains insert 1100 add overflow block: 1 1 1101 1100 1101 1101 1100 CS 245 Notes 5

Extensible hashing Summary Can handle growing files - with less wasted space - with no full reorganizations + CS 245 Notes 5

Extensible hashing Summary Can handle growing files - with less wasted space - with no full reorganizations + Indirection (Not bad if directory in memory) Directory doubles in size (Now it fits, now it does not) - CS 245 Notes 5

Linear hashing Another dynamic hashing scheme Two ideas: (a) Use i low order bits of hash 01110101 grows b i CS 245 Notes 5

Linear hashing Another dynamic hashing scheme Two ideas: (a) Use i low order bits of hash 01110101 grows b i (b) File grows linearly CS 245 Notes 5

Example b=4 bits, i =2, 2 keys/bucket Future growth buckets 0000 0101 1010 1111 00 01 10 11 m = 01 (max used block) CS 245 Notes 5

Example b=4 bits, i =2, 2 keys/bucket Future growth buckets 0000 0101 1010 1111 00 01 10 11 m = 01 (max used block) If h(k)[i ]  m, then look at bucket h(k)[i ] else, look at bucket h(k)[i ] - 2i -1 Rule CS 245 Notes 5

Example b=4 bits, i =2, 2 keys/bucket insert 0101 Future growth buckets 0000 0101 1010 1111 00 01 10 11 m = 01 (max used block) If h(k)[i ]  m, then look at bucket h(k)[i ] else, look at bucket h(k)[i ] - 2i -1 Rule CS 245 Notes 5

Example b=4 bits, i =2, 2 keys/bucket 0101 can have overflow chains! insert 0101 Future growth buckets 0000 0101 1010 1111 00 01 10 11 m = 01 (max used block) If h(k)[i ]  m, then look at bucket h(k)[i ] else, look at bucket h(k)[i ] - 2i -1 Rule CS 245 Notes 5

Note In textbook, n is used instead of m n=m+1 n=10 0000 0101 1010 Future growth buckets 0000 0101 1010 1111 00 01 10 11 m = 01 (max used block) CS 245 Notes 5

Example b=4 bits, i =2, 2 keys/bucket Future growth buckets 0000 0101 1010 1111 00 01 10 11 m = 01 (max used block) CS 245 Notes 5

Example b=4 bits, i =2, 2 keys/bucket Future growth buckets 0000 1010 0101 10 1010 1111 00 01 10 11 m = 01 (max used block) CS 245 Notes 5

Example b=4 bits, i =2, 2 keys/bucket 0101 insert 0101 Future growth buckets 0000 1010 0101 10 1010 1111 00 01 10 11 m = 01 (max used block) CS 245 Notes 5

Example b=4 bits, i =2, 2 keys/bucket 0101 insert 0101 Future growth buckets 11 0000 1010 0101 10 1010 1111 00 01 10 11 m = 01 (max used block) CS 245 Notes 5

Example b=4 bits, i =2, 2 keys/bucket 0101 insert 0101 1111 0101 Future growth buckets 11 0000 1010 0101 10 1010 1111 00 01 10 11 m = 01 (max used block) CS 245 Notes 5

Example Continued: How to grow beyond this? 0000 0101 1010 1111 0101 00 01 10 11 . . . m = 11 (max used block) CS 245 Notes 5

Example Continued: How to grow beyond this? 100 101 110 111 3 i = 2 0000 0101 1010 1111 0101 00 01 10 11 . . . m = 11 (max used block) CS 245 Notes 5

Example Continued: How to grow beyond this? 100 101 110 111 3 i = 2 0000 100 0101 1010 1111 0101 00 01 10 11 . . . m = 11 (max used block) CS 245 Notes 5

Example Continued: How to grow beyond this? 100 101 110 111 3 i = 2 0000 100 0101 101 0101 1010 1111 0101 00 01 10 11 . . . m = 11 (max used block) CS 245 Notes 5

 When do we expand file? Keep track of: # used slots = U total # of slots = U CS 245 Notes 5

 When do we expand file? Keep track of: # used slots = U total # of slots = U If U > threshold then increase m (and maybe i ) CS 245 Notes 5

Linear Hashing Summary Can handle growing files - with less wasted space - with no full reorganizations No indirection like extensible hashing + + Can still have overflow chains - CS 245 Notes 5

Example: BAD CASE Very full Very empty Need to move m here… Would waste space... CS 245 Notes 5

Summary Hashing - How it works - Dynamic hashing - Extensible - Linear CS 245 Notes 5

Next: Indexing vs Hashing Index definition in SQL Multiple key access CS 245 Notes 5

Indexing vs Hashing Hashing good for probes given key e.g., SELECT … FROM R WHERE R.A = 5 CS 245 Notes 5

Indexing vs Hashing INDEXING (Including B Trees) good for Range Searches: e.g., SELECT FROM R WHERE R.A > 5 CS 245 Notes 5

Index definition in SQL Create index name on rel (attr) Create unique index name on rel (attr) defines candidate key Drop INDEX name CS 245 Notes 5

CANNOT SPECIFY TYPE OF INDEX (e.g. B-tree, Hashing, …) OR PARAMETERS (e.g. Load Factor, Size of Hash,...) ... at least in SQL... Note CS 245 Notes 5

ATTRIBUTE LIST  MULTIKEY INDEX (next) e.g., CREATE INDEX foo ON R(A,B,C) Note CS 245 Notes 5

Multi-key Index Motivation: Find records where DEPT = “Toy” AND SAL > 50k CS 245 Notes 5

Strategy I: Use one index, say Dept. Get all Dept = “Toy” records and check their salary I1 CS 245 Notes 5

Strategy II: Use 2 Indexes; Manipulate Pointers Toy Sal > 50k CS 245 Notes 5

Strategy III: Multiple Key Index One idea: I2 I3 I1 CS 245 Notes 5

Example Example Record Dept Index Salary 10k 15k Art Sales Toy 17k 21k Name=Joe DEPT=Sales SAL=15k 12k 15k 15k 19k CS 245 Notes 5

For which queries is this index good? Find RECs Dept = “Sales” SAL=20k Find RECs Dept = “Sales” SAL > 20k Find RECs Dept = “Sales” Find RECs SAL = 20k CS 245 Notes 5

Interesting application: Geographic Data DATA: <X1,Y1, Attributes> <X2,Y2, Attributes> y x . . . CS 245 Notes 5

Queries: What city is at <Xi,Yi>? What is within 5 miles from <Xi,Yi>? Which is closest point to <Xi,Yi>? CS 245 Notes 5

Example a i d e h b n f l o c j g m k CS 245 Notes 5

Example a 10 20 i d e h b n f l o c j g m k CS 245 Notes 5

Example 25 15 35 20 40 30 10 10 20 a i d e h b n f l o c j g m k 15 35 20 40 30 10 10 20 i d e h b n f l o c j g m k CS 245 Notes 5

Example 25 15 35 20 40 30 10 10 20 5 15 a i d e h b n f l o c j g m k 15 35 20 40 30 10 10 20 i d e h b n f 5 15 l o c j g m k CS 245 Notes 5

Example 25 15 35 20 40 30 10 10 20 5 15 h i a b c d e f g n o m l j k 15 35 20 40 30 10 10 20 i d e h b n f 5 15 l o c j g m k h i a b c d e f g n o m l j k CS 245 Notes 5

Example 25 15 35 20 40 30 10 10 20 Search points near f 15 35 20 40 30 10 10 20 i d e h Search points near f Search points near b b n f 5 15 l o c j g m k h i a b c d e f g n o m l j k CS 245 Notes 5

Queries Find points with Yi > 20 Find points with Xi < 5 Find points “close” to i = <12,38> Find points “close” to b = <7,24> CS 245 Notes 5

Many types of geographic index structures have been suggested kd-Trees (very similar to what we described here) Quad Trees R Trees ... CS 245 Notes 5

Two more types of multi key indexes Grid Partitioned hash CS 245 Notes 5

Grid Index Key 2 X1 X2 …… Xn V2 Key 1 Vn V1 To records with key1=V3, key2=X2 CS 245 Notes 5

CLAIM Can quickly find records with key 1 = Vi  Key 2 = Xj key 1 = Vi CS 245 Notes 5

CLAIM Can quickly find records with And also ranges…. key 1 = Vi  Key 2 = Xj key 1 = Vi key 2 = Xj And also ranges…. E.g., key 1  Vi  key 2 < Xj CS 245 Notes 5

How do we find entry i,j in linear structure? max number of i values N=4 i, j position S+0 position S+1 position S+2 position S+3 pos(i, j) = position S+4 position S+9 pos(i, j) = S + iN + j CS 245 Notes 5

How do we find entry i,j in linear structure? max number of i values N=4 i, j position S+0 position S+1 position S+2 position S+3 pos(i, j) = S + iN + j position S+4 Issue: Cells must be same size, and N must be constant! position S+9 pos(i, j) = S + iN + j Issue: Some cells may overflow, some may be sparse... CS 245 Notes 5

Solution: Use Indirection Buckets V1 V2 V3 *Grid only V4 contains pointers to buckets X1 X2 X3 -- -- -- -- -- CS 245 Notes 5

With indirection: Grid can be regular without wasting space We do have price of indirection CS 245 Notes 5

Can also index grid on value ranges Salary Grid 0-20K 1 20K-50K 2 50K- 8 3 Linear Scale 1 2 3 Toy Sales Personnel CS 245 Notes 5

Grid files Good for multiple-key search Space, management overhead (nothing is free) Need partitioning ranges that evenly split keys + - - CS 245 Notes 5

Partitioned hash function 010110 1110010 Idea: Key1 Key2 h1 h2 CS 245 Notes 5

EX: h1(toy) =0 000 h1(sales) =1 001 h1(art) =1 010 . 011 . . 011 . h2(10k) =01 100 h2(20k) =11 101 h2(30k) =01 110 h2(40k) =00 111 <Fred,toy,10k>,<Joe,sales,10k> <Sally,art,30k> Insert CS 245 Notes 5

<Joe><Sally> EX: h1(toy) =0 000 h1(sales) =1 001 h1(art) =1 010 . 011 . h2(10k) =01 100 h2(20k) =11 101 h2(30k) =01 110 h2(40k) =00 111 <Fred,toy,10k>,<Joe,sales,10k> <Sally,art,30k> <Joe><Sally> <Fred> Insert CS 245 Notes 5

Find Emp. with Dept. = Sales  Sal=40k h1(toy) =0 000 h1(sales) =1 001 h1(art) =1 010 . 011 . h2(10k) =01 100 h2(20k) =11 101 h2(30k) =01 110 h2(40k) =00 111 Find Emp. with Dept. = Sales  Sal=40k <Fred> <Joe><Jan> <Mary> <Sally> <Tom><Bill> <Andy> CS 245 Notes 5

Find Emp. with Dept. = Sales  Sal=40k h1(toy) =0 000 h1(sales) =1 001 h1(art) =1 010 . 011 . h2(10k) =01 100 h2(20k) =11 101 h2(30k) =01 110 h2(40k) =00 111 Find Emp. with Dept. = Sales  Sal=40k <Fred> <Joe><Jan> <Mary> <Sally> <Tom><Bill> <Andy> CS 245 Notes 5

h1(toy) =0 000 h1(sales) =1 001 h1(art) =1 010 . 011 . h2(10k) =01 100 . 011 . h2(10k) =01 100 h2(20k) =11 101 h2(30k) =01 110 h2(40k) =00 111 Find Emp. with Sal=30k <Fred> <Joe><Jan> <Mary> <Sally> <Tom><Bill> <Andy> CS 245 Notes 5

h1(toy) =0 000 h1(sales) =1 001 h1(art) =1 010 . 011 . h2(10k) =01 100 . 011 . h2(10k) =01 100 h2(20k) =11 101 h2(30k) =01 110 h2(40k) =00 111 Find Emp. with Sal=30k <Fred> look here <Joe><Jan> <Mary> <Sally> <Tom><Bill> <Andy> CS 245 Notes 5

Find Emp. with Dept. = Sales h1(toy) =0 000 h1(sales) =1 001 h1(art) =1 010 . 011 . h2(10k) =01 100 h2(20k) =11 101 h2(30k) =01 110 h2(40k) =00 111 Find Emp. with Dept. = Sales <Fred> <Joe><Jan> <Mary> <Sally> <Tom><Bill> <Andy> CS 245 Notes 5

Find Emp. with Dept. = Sales h1(toy) =0 000 h1(sales) =1 001 h1(art) =1 010 . 011 . h2(10k) =01 100 h2(20k) =11 101 h2(30k) =01 110 h2(40k) =00 111 Find Emp. with Dept. = Sales <Fred> <Joe><Jan> <Mary> look here <Sally> <Tom><Bill> <Andy> CS 245 Notes 5

Summary Post hashing discussion: - Indexing vs. Hashing - SQL Index Definition - Multiple Key Access - Multi Key Index Variations: Grid, Geo Data - Partitioned Hash CS 245 Notes 5

Reading Chapter 5 Skim the following sections: Read the rest Sections 14.3.6, 14.3.7, 14.3.8 [Second Ed: 14.6.6, 14.6.7, 14.6.8] Sections 14.4.2, 14.4.3, 14.4.4 [Second Ed: 14.7.2, 14.7.3, 14.7.4] Read the rest CS 245 Notes 5

The BIG picture…. Chapters 11 & 12 [13]: Storage, records, blocks... Chapters 13 & 14 [14]: Access Mechanisms - Indexes - B trees - Hashing - Multi key Chapters 15 & 16 [15, 16]: Query Processing NEXT CS 245 Notes 5