<<

DATA ANALYTICS USING DEEP LEARNING GT 8803 // FALL 2019 // JOY ARULRAJ

LECTURE #08:QUERY EXECUTION administrivia

• Reminders – Sign up for discussion slots on Thursday – Proposal presentations on next Wednesday – 2 page document + 5 minute presentation – Assignment 1 due on Wednesday

GT 8803 // Fall 2019 2 LAST

• Storage models: NSM, DSM, and FSM FLEXIBLE STORAGE MODEL

ID University Enrollment City

1 Georgia Tech 15000 Atlanta 2 Wisconsin 30000 Madison

3 Carnegie Mellon 6000 Pittsburgh 4 UC Berkeley 30000 Berkeley

GT 8803 // Fall 2019 3 LAST CLASS

• Compression – Zone maps – Dictionary encoding Original Data

val 100 200 300 400 400

GT 8803 // Fall 2019 4 LAST CLASS

• Compression – Zone maps – Dictionary encoding Original Data Zone Map

val type val 100 MIN 100 200 MAX 400 300 AVG 280 400 SUM 1400 400 COUNT 5

GT 8803 // Fall 2019 5 LAST CLASS

• Compression SELECT * FROM table – Zone maps WHERE val > 600 – Dictionary encoding Original Data Zone Map

val type val 100 MIN 100 200 MAX 400 300 AVG 280 400 SUM 1400 400 COUNT 5

GT 8803 // Fall 2019 6 LAST CLASS

• Visual Storage Engine – Convolutional Auto Encoder COMPRESSED DATA

ENCODER DECODER (CONVOLUTIONS) (DECONVOLUTIONS)

GT 8803 // Fall 2019 7 TODAY’s AGENDA

• Query Processing Models • Access Methods • Expression Evaluation • Visual Query Execution Engine

GT 8803 // Fall 2019 8 QUERY PROCESSING MODELS

GT 8803 // Fall 2018 9 ANATOMY OF A DATABASE SYSTEM

Connection Manager + Admission Control Process Manager Query Parser Query Optimizer Query Processor Query Executor Query Lock Manager (Concurrency Control) Access Methods (or Indexes) Transactional Storage Manager Buffer Pool Manager Log Manager Memory Manager + Disk Manager Shared Utilities Networking Manager Source: Anatomy of a Database System GT 8803 // Fall 2019 10 QUERY PLAN

• The operators are arranged in a tree. – Data flows from the leaves toward the root. – Output of the root node is the result of the query.

A.id, B.value SELECT A.id, B.value p FROM A, B WHERE A.id = B.id ⨝ A.id=B.id AND B.value > 100 s value>100 AB GT 8803 // Fall 2019 11 QUERY PROCESSING MODELS

• A DBMS's processing model defines how the system executes a query plan. – Different trade-offs for different workloads. – Top-down or Bottom-up execution – Determines what data is sent between operators • Three approaches: – -at-a-time Model – Operator-at-a-time Model – Vector-at-a-time Model

GT 8803 // Fall 2019 12 #1: TUPLE-AT-A-TIME MODEL

• Each query plan operator implements a next . – On each invocation, the operator returns either a single tuple or a null marker if there are no more . – The operator implements a loop that calls next on its children to retrieve their tuples and then process them. • Top-down plan processing. • Also called Iterator / Volcano / Pipeline model.

GT 8803 // Fall 2019 13 #1: TUPLE-AT-A-TIME MODEL

SELECT A.id, B.value FROM A, B WHERE A.id = B.id AND B.value > 100

p A.id, B.value

⨝ A.id=B.id

s value>100 AB GT 8803 // Fall 2018 14 #1: TUPLE-AT-A-TIME MODEL

SELECT A.id, B.value for t in child.Next(): emit((t)) FROM A, B WHERE A.id = B.id AND for t1 in left.Next(): B.value > 100 buildHashTable(t1) for t in right.Next(): 2 p A.id, B.value if probe(t2): emit(t1⨝t2) for t in child.Next(): ⨝ A.id=B.id if evalPred(t): emit(t) s value>100 for t in A: for t in B: emit(t) emit(t) AB GT 8803 // Fall 2018 15 #1: TUPLE-AT-A-TIME MODEL

SELECT A.id, B.value for t in child.Next(): emit(projection(t)) FROM A, B WHERE A.id = B.id AND for t1 in left.Next(): B.value > 100 buildHashTable(t1) for t in right.Next(): 2 p A.id, B.value if probe(t2): emit(t1⨝t2) for t in child.Next(): ⨝ A.id=B.id if evalPred(t): emit(t) s value>100 for t in A: for t in B: emit(t) emit(t) AB GT 8803 // Fall 2018 16 #1: TUPLE-AT-A-TIME MODEL

SELECT A.id, B.value for t in child.Next(): FROM 1 emit(projection(t)) A, B WHERE A.id = B.id AND for t1 in left.Next(): B.value > 100 buildHashTable(t1) for t in right.Next(): 2 p A.id, B.value if probe(t2): emit(t1⨝t2) for t in child.Next(): ⨝ A.id=B.id if evalPred(t): emit(t) s value>100 for t in A: for t in B: emit(t) emit(t) AB GT 8803 // Fall 2018 17 #1: TUPLE-AT-A-TIME MODEL

SELECT A.id, B.value for t in child.Next(): FROM 1 emit(projection(t)) A, B WHERE A.id = B.id AND for t1 in left.Next(): B.value > 100 buildHashTable(t1) for t in right.Next(): 2 p A.id, B.value if probe(t2): emit(t1⨝t2) for t in child.Next(): ⨝ A.id=B.id if evalPred(t): emit(t) s value>100 for t in A: for t in B: emit(t) emit(t) AB GT 8803 // Fall 2018 18 #1: TUPLE-AT-A-TIME MODEL

SELECT A.id, B.value for t in child.Next(): FROM 1 emit(projection(t)) A, B WHERE A.id = B.id AND for t1 in left.Next(): B.value > 100 buildHashTable(t ) 2 1 for t in right.Next(): 2 p A.id, B.value if probe(t2): emit(t1⨝t2) for t in child.Next(): ⨝ A.id=B.id if evalPred(t): emit(t) s value>100 for t in A: for t in B: emit(t) emit(t) AB GT 8803 // Fall 2018 19 #1: TUPLE-AT-A-TIME MODEL

SELECT A.id, B.value for t in child.Next(): FROM 1 emit(projection(t)) A, B WHERE A.id = B.id AND for t1 in left.Next(): B.value > 100 buildHashTable(t ) 2 1 for t in right.Next(): 2 p A.id, B.value if probe(t2): emit(t1⨝t2) for t in child.Next(): ⨝ A.id=B.id if evalPred(t): emit(t) s value>100 for t in A: for t in B: 3 emit(t) emit(t) AB GT 8803 // Fall 2018 20 #1: TUPLE-AT-A-TIME MODEL

SELECT A.id, B.value for t in child.Next(): FROM 1 emit(projection(t)) A, B WHERE A.id = B.id AND for t1 in left.Next(): B.value > 100 buildHashTable(t ) 2 1 for t in right.Next(): 2 p A.id, B.value if probe(t2): emit(t1⨝t2) for t in child.Next(): ⨝ A.id=B.id if evalPred(t): 4 emit(t) s value>100 for t in A: for t in B: 3 emit(t) emit(t) 5 AB GT 8803 // Fall 2018 21 #1: TUPLE-AT-A-TIME MODEL

• This is used in every DBMS. – Allows for tuple pipelining. • Some operators will block until children emit all of their tuples. – Joins, Subqueries, Order By – Known as pipeline breakers • Output control works easily with this approach. – Limit

GT 8803 // Fall 2019 22 #2: OPERATOR-AT-A-TIME MODEL

• Each operator processes its input all at once and then emits its output all at once. – The operator "materializes" it output as a single result. – The DBMS can push down hints into to avoid scanning too many tuples. • Bottom-up plan processing.

GT 8803 // Fall 2019 23 #2: OPERATOR-AT-A-TIME MODEL

out = { } SELECT A.id, B.value for t in child.Output(): FROM A, B out.add(projection(t)) WHERE A.id = B.id out = { } AND B.value > 100 for t1 in left.Output(): buildHashTable(t ) 1 p A.id, B.value for t2 in right.Output(): if probe(t2): out.add(t1⨝t2) out = { } ⨝ A.id=B.id for t in child.Output(): if evalPred(t): out.add(t) s value>100 out = { } out = { } for t in A: for t in B: out.add(t) out.add(t) AB GT 8803 // Fall 2018 24 #2: OPERATOR-AT-A-TIME MODEL

out = { } SELECT A.id, B.value for t in child.Output(): FROM A, B out.add(projection(t)) WHERE A.id = B.id out = { } AND B.value > 100 for t1 in left.Output(): buildHashTable(t ) 1 p A.id, B.value for t2 in right.Output(): if probe(t2): out.add(t1⨝t2) out = { } ⨝ A.id=B.id for t in child.Output(): if evalPred(t): out.add(t) s value>100 out = { } out = { } 1 for t in A: for t in B: out.add(t) out.add(t) AB GT 8803 // Fall 2018 25 #2: OPERATOR-AT-A-TIME MODEL

out = { } SELECT A.id, B.value for t in child.Output(): FROM A, B out.add(projection(t)) WHERE A.id = B.id out = { } AND B.value > 100 for t1 in left.Output(): buildHashTable(t ) 1 p A.id, B.value for t2 in right.Output(): if probe(t2): out.add(t1⨝t2) out = { } ⨝ A.id=B.id for t in child.Output(): if evalPred(t): out.add(t) s value>100 out = { } out = { } 1 for t in A: for t in B: out.add(t) out.add(t) AB GT 8803 // Fall 2018 26 #2: OPERATOR-AT-A-TIME MODEL

out = { } SELECT A.id, B.value for t in child.Output(): FROM A, B out.add(projection(t)) WHERE A.id = B.id out = { } AND B.value > 100 for t1 in left.Output(): buildHashTable(t ) 1 p A.id, B.value for t2 in right.Output(): if probe(t2): out.add(t1⨝t2) out = { } ⨝ A.id=B.id for t in child.Output(): if evalPred(t): out.add(t) s value>100 out = { } out = { } 1 for t in A: for t in B: 2 out.add(t) out.add(t) AB GT 8803 // Fall 2018 27 #2: OPERATOR-AT-A-TIME MODEL

out = { } SELECT A.id, B.value for t in child.Output(): FROM A, B out.add(projection(t)) WHERE A.id = B.id out = { } AND B.value > 100 for t1 in left.Output(): buildHashTable(t ) 1 p A.id, B.value for t2 in right.Output(): if probe(t2): out.add(t1⨝t2) out = { } ⨝ A.id=B.id for t in child.Output(): 3 if evalPred(t): out.add(t) s value>100 out = { } out = { } 1 for t in A: for t in B: 2 out.add(t) out.add(t) AB GT 8803 // Fall 2018 28 #2: OPERATOR-AT-A-TIME MODEL

out = { } SELECT A.id, B.value for t in child.Output(): FROM A, B out.add(projection(t)) WHERE A.id = B.id out = { } AND B.value > 100 for t in left.Output(): 4 1 buildHashTable(t ) 1 p A.id, B.value for t2 in right.Output(): if probe(t2): out.add(t1⨝t2) out = { } ⨝ A.id=B.id for t in child.Output(): 3 if evalPred(t): out.add(t) s value>100 out = { } out = { } 1 for t in A: for t in B: 2 out.add(t) out.add(t) AB GT 8803 // Fall 2018 29 #2: OPERATOR-AT-A-TIME MODEL

out = { } SELECT A.id, B.value 5 for t in child.Output(): FROM A, B out.add(projection(t)) WHERE A.id = B.id out = { } AND B.value > 100 for t in left.Output(): 4 1 buildHashTable(t ) 1 p A.id, B.value for t2 in right.Output(): if probe(t2): out.add(t1⨝t2) out = { } ⨝ A.id=B.id for t in child.Output(): 3 if evalPred(t): out.add(t) s value>100 out = { } out = { } 1 for t in A: for t in B: 2 out.add(t) out.add(t) AB GT 8803 // Fall 2018 30 #2: OPERATOR-AT-A-TIME MODEL

• Better for OLTP workloads – Transactions typically only access a small number of tuples at a time. – Lower execution / coordination overhead.

• Not good for OLAP queries with large intermediate results.

GT 8803 // Fall 2019 31 #3: VECTOR-AT-A-TIME MODEL

• Like tuple-at-a-time model, each operator implements a next function. • Each operator emits a vector (i.e., batch) of tuples instead of a single tuple. – The operator's internal loop processes multiple tuples at a time. – The size of the batch can vary based on hardware or query properties.

GT 8803 // Fall 2019 32 #3: VECTOR-AT-A-TIME MODEL out = { } for t in child.Next(): SELECT A.id, B.value out.add(projection(t)) if |out|> n: emit(out) FROM A, B WHERE A.id = B.id out = { } AND B.value > 100 for t1 in left.Next(): buildHashTable(t1) for t in right.Next(): 2 p A.id, B.value if probe(t2): out.add(t1⨝t2) if |out|> n: emit(out) out = { } ⨝ A.id=B.id for t in child.Next(): if evalPred(t): out.add(t) if |out|> n : emit(out) s value>100 out = { } out = { } for t in A: for t in B: out.add(t) out.add(t) AB if |out|> n : emit(out) if |out|> n : emit(out) GT 8803 // Fall 2018 33 #3: VECTOR-AT-A-TIME MODEL out = { } for t in child.Next(): 1 SELECT A.id, B.value out.add(projection(t)) if |out|> n: emit(out) FROM A, B WHERE A.id = B.id out = { } AND B.value > 100 2 for t1 in left.Next(): buildHashTable(t1) for t in right.Next(): 2 p A.id, B.value if probe(t2): out.add(t1⨝t2) if |out|> n: emit(out) out = { } ⨝ A.id=B.id for t in child.Next(): if evalPred(t): out.add(t) if |out|> n : emit(out) s value>100 out = { } out = { } 3 for t in A: for t in B: out.add(t) out.add(t) AB if |out|> n : emit(out) if |out|> n : emit(out) GT 8803 // Fall 2018 34 #3: VECTOR-AT-A-TIME MODEL out = { } for t in child.Next(): 1 SELECT A.id, B.value out.add(projection(t)) if |out|> n: emit(out) FROM A, B WHERE A.id = B.id out = { } AND B.value > 100 2 for t1 in left.Next(): buildHashTable(t1) for t in right.Next(): 2 p A.id, B.value if probe(t2): out.add(t1⨝t2) if |out|> n: emit(out) out = { } ⨝ A.id=B.id for t in child.Next(): 4 if evalPred(t): out.add(t) if |out|> n : emit(out) s value>100 out = { } out = { } 3 for t in A: for t in B: 5 out.add(t) out.add(t) AB if |out|> n : emit(out) if |out|> n : emit(out) GT 8803 // Fall 2018 35 #3: VECTOR-AT-A-TIME MODEL

GT 8803 // Fall 2019 36 #3: VECTOR-AT-A-TIME MODEL

• Q: What is the target workload for this model: OLTP or OLAP? – Reduces number of next function invocations – Works well for OLAP • Q: Why is it better than operator-at-a-time model in traditional disk-centric DBMSs? – Intermediate tables may not fit in main-memory – Fetching batches of tuples reduces number of page accesses

GT 8803 // Fall 2019 37 #3: VECTOR-AT-A-TIME MODEL

• Q: What is the target workload for this model: OLTP or OLAP? – Reduces number of next function invocations – Works well for OLAP • Q: Why is it better than operator-at-a-time model in traditional disk-centric DBMSs? – Intermediate tables may not fit in main-memory – Fetching batches of tuples reduces number of page accesses

GT 8803 // Fall 2019 38 #3: VECTOR-AT-A-TIME MODEL

• Q: What is the target workload for this model: OLTP or OLAP? – Reduces number of next function invocations – Works well for OLAP • Q: Why is it better than operator-at-a-time model in traditional disk-centric DBMSs? – Intermediate tables may not fit in main-memory – Fetching batches of tuples reduces number of page accesses

GT 8803 // Fall 2019 39 #3: VECTOR-AT-A-TIME MODEL

• Ideal for OLAP queries – Greatly reduces the number of invocations per operator. – Allows for operators to use vectorized instructions (SIMD) to process batches of tuples.

GT 8803 // Fall 2019 40 QUERY PROCESSING MODELS: SUMMARY

Tuple-at-a-time →Direction: Top-Down →Emits: Single Tuple →Target: General Purpose

Operator-at-a-time Vector-at-a-time →Direction: Bottom-Up →Direction: Top-Down →Emits: Entire Tuple →Emits: Tuple Batch →Target: OLTP →Target: OLAP

GT 8803 // Fall 2018 41 ACCESS METHODS

SELECT A.id, B.value • An access method is a way that FROM A, B WHERE A.id = B.id the DBMS can access the AND B.value > 100 data stored in a table. – Not defined in p A.id, B.value – Physical database design • Three basic methods: ⨝ A.id=B.id – Sequential Scan s value>100 – Index Scan – Multi-index / "Bitmap" Scan AB GT 8803 // Fall 2019 42 ACCESS METHODS

SELECT A.id, B.value • An access method is a way that FROM A, B WHERE A.id = B.id the DBMS can access the AND B.value > 100 data stored in a table. – Not defined in relational algebra p A.id, B.value – Physical database design • Three basic methods: ⨝ A.id=B.id – Sequential Scan s value>100 – Index Scan – Multi-index / "Bitmap" Scan AB GT 8803 // Fall 2019 43 #1: SEQUENTIAL SCAN

• For each page in the table: for page in table.pages: – Retrieve it from the buffer pool. for t in page.tuples: – Iterate over each tuple and if evalPred (t): // Do Something! check whether to include it.

• The DBMS maintains an internal cursor that tracks the last page / slot it examined.

GT 8803 // Fall 2019 44 #1: SEQUENTIAL SCAN

• This is almost always the worst thing that the DBMS can do to execute a query. • Sequential scan optimizations: – Prefetching – Parallelization – Buffer Pool Bypass – Zone Maps – Late materialization – Heap clustering

GT 8803 // Fall 2019 45 #1: SEQUENTIAL SCAN

• This is almost always the worst thing that the DBMS can do to execute a query. • Sequential scan optimizations: – Prefetching – Parallelization – Buffer Pool Bypass – Zone Maps – Late materialization – Heap clustering

GT 8803 // Fall 2019 46 ZONE MAPS

• Pre-computed aggregates for the attribute values in a page. – DBMS checks the zone map first to decide whether it wants to access the page. Original Data val 100 200 300 400 400

GT 8803 // Fall 2019 47 ZONE MAPS

• Pre-computed aggregates for the attribute values in a page. – DBMS checks the zone map first to decide whether it wants to access the page. Original Data Zone Map val type val 100 MIN 100 200 MAX 400 300 AVG 280 400 SUM 1400 400 COUNT 5

GT 8803 // Fall 2019 48 ZONE MAPS

• Pre-computed aggregates for the attribute values in a page. – DBMS checks the zone map first to decide whether it wants to access the page. Original Data Zone Map val type val SELECT * FROM table 100 MIN 100 WHERE val > 600 200 MAX 400 300 AVG 280 400 SUM 1400 400 COUNT 5

GT 8803 // Fall 2019 49 LATE MATERIALIZATION

• DSM DBMSs can delay stitching together tuples until the upper parts of the query plan.

GT 8803 // Fall 2019 50 LATE MATERIALIZATION

• DSM DBMSs can delay stitching together tuples until the upper parts of the query plan. SELECT AVG(C) FROM foo JOIN bar ON foo.b = bar.b WHERE a > 100

a b c 0 1 2 3 GT 8803 // Fall 2019 51 LATE MATERIALIZATION

• DSM DBMSs can delay stitching together tuples until the upper parts of the query plan. SELECT AVG(C) AVG(c) FROM foo JOIN bar γ ON foo.b = bar.b WHERE a > 100 ⨝ foo.b=bar.b a b c s a>100 0 1 2 bar foo 3 GT 8803 // Fall 2019 52 LATE MATERIALIZATION

• DSM DBMSs can delay stitching together tuples until the upper parts of the query plan. SELECT AVG(C) AVG(c) FROM foo JOIN bar γ ON foo.b = bar.b WHERE a > 100 ⨝ foo.b=bar.b a b c s a>100 0 1 2 bar foo 3 GT 8803 // Fall 2019 53 LATE MATERIALIZATION

• DSM DBMSs can delay stitching together tuples until the upper parts of the query plan. SELECT AVG(C) AVG(c) FROM foo JOIN bar γ ON foo.b = bar.b WHERE a > 100 ⨝ foo.b=bar.b a b c s a>100 0 1 2 bar foo 3 GT 8803 // Fall 2019 54 LATE MATERIALIZATION

• DSM DBMSs can delay stitching together tuples until the upper parts of the query plan. SELECT AVG(C) AVG(c) FROM foo JOIN bar γ ON foo.b = bar.b WHERE a > 100 ⨝ foo.b=bar.b a b c s a>100 Offsets 0 1 2 bar foo 3 GT 8803 // Fall 2019 55 LATE MATERIALIZATION

• DSM DBMSs can delay stitching together tuples until the upper parts of the query plan. SELECT AVG(C) AVG(c) FROM foo JOIN bar γ ON foo.b = bar.b WHERE a > 100 ⨝ foo.b=bar.b Offsets a b c s a>100 Offsets 0 1 2 bar foo 3 GT 8803 // Fall 2019 56 LATE MATERIALIZATION

• DSM DBMSs can delay stitching together tuples until the upper parts of the query plan. SELECT AVG(C) FROM JOIN AVG(c) Result foo bar γ ON foo.b = bar.b WHERE a > 100 ⨝ foo.b=bar.b Offsets a b c s a>100 Offsets 0 1 2 bar foo 3 GT 8803 // Fall 2019 57 HEAP CLUSTERING

• Tuples are sorted in the heap's pages using the order specified by the clustering index. 101 102 103 104 • If the query accesses tuples using the clustering index's attributes, then the DBMS can jump directly to the pages that it needs.

GT 8803 // Fall 2019 58 HEAP CLUSTERING

• Tuples are sorted in the Scan Direction heap's pages using the order specified by the clustering index. 101 102 103 104 • If the query accesses tuples using the clustering index's attributes, then the DBMS can jump directly to the pages that it needs.

GT 8803 // Fall 2019 59 HEAP CLUSTERING

• Tuples are sorted in the Scan Direction heap's pages using the order specified by the clustering index. 101 102 103 104 • If the query accesses tuples using the clustering index's attributes, then the DBMS can jump directly to the pages that it needs.

GT 8803 // Fall 2019 60 #2: INDEX SCAN

• The DBMS picks an index to find the tuples that the query needs.

• Which index to use depends on: – What attributes the index contains – What attributes the query references – The attribute's value domains – Predicate composition – Whether the index has unique or non-unique keys

GT 8803 // Fall 2019 61 #2: INDEX SCAN

• The DBMS picks an index to find the tuples that the query needs.

• Which index to use depends on: – What attributes the index contains – What attributes the query references – The attribute's value domains – Predicate composition – Whether the index has unique or non-unique keys

GT 8803 // Fall 2019 62 #2: INDEX SCAN

• Suppose that we a single table SELECT * FROM students WHERE age < 30 with 100 tuples and 2 indexes: AND dept = 'CS' – Index #1: age AND country = 'US' – Index #2: dept

GT 8803 // Fall 2019 63 #2: INDEX SCAN

• Suppose that we a single table SELECT * FROM students WHERE age < 30 with 100 tuples and 2 indexes: AND dept = 'CS' – Index #1: age AND country = 'US' – Index #2: dept Scenario #1 There are 99 people under the age of 30 but only 2 people in the CS department.

GT 8803 // Fall 2019 64 #2: INDEX SCAN

• Suppose that we a single table SELECT * FROM students WHERE age < 30 with 100 tuples and 2 indexes: AND dept = 'CS' – Index #1: age AND country = 'US' – Index #2: dept Scenario #1 Scenario #2 There are 99 people There are 99 people in under the age of 30 the CS department but but only 2 people in only 2 people under the CS department. the age of 30.

GT 8803 // Fall 2019 65 #3: MULTI-INDEX SCAN

• If there are multiple indexes that the DBMS can use for a query: – Compute sets of record ids using each matching index. – Combine these sets based on the query's predicates ( vs. intersect). – Retrieve the records and apply any remaining terms. • Postgres calls this Bitmap Scan

GT 8803 // Fall 2019 66 #3: MULTI-INDEX SCAN

• With an index on age and an index SELECT * FROM students WHERE age < 30 on dept, AND dept = 'CS' – We can retrieve the record ids AND country = 'US' satisfying age<30 using the first, – Then retrieve the record ids satisfying dept='CS' using the second, – Take their intersection – Retrieve records and check country='US'.

GT 8803 // Fall 2019 67 #3: MULTI-INDEX SCAN

• Set intersection can be done SELECT * FROM students WHERE age < 30 with bitmaps, hash tables, AND dept = 'CS' or Bloom filters. AND country = 'US' age<30 dept='CS'

GT 8803 // Fall 2019 68 #3: MULTI-INDEX SCAN

• Set intersection can be done SELECT * FROM students WHERE age < 30 with bitmaps, hash tables, AND dept = 'CS' or Bloom filters. AND country = 'US' age<30 dept='CS'

record ids

GT 8803 // Fall 2019 69 #3: MULTI-INDEX SCAN

• Set intersection can be done SELECT * FROM students WHERE age < 30 with bitmaps, hash tables, AND dept = 'CS' or Bloom filters. AND country = 'US' age<30 dept='CS'

record ids record ids

GT 8803 // Fall 2019 70 #3: MULTI-INDEX SCAN

• Set intersection can be done SELECT * FROM students WHERE age < 30 with bitmaps, hash tables, AND dept = 'CS' or Bloom filters. AND country = 'US' age<30 dept='CS'

record ids record ids

fetch records country='US'

GT 8803 // Fall 2019 71 INDEX SCAN PAGE SORTING

• Retrieving tuples in the order that appear in an unclustered index is inefficient. 101 102 103 104 • The DBMS can first figure out all the tuples that it needs and then sort them based on their page id.

GT 8803 // Fall 2019 72 INDEX SCAN PAGE SORTING

Scan Direction • Retrieving tuples in the order that appear in an unclustered index is inefficient. 101 102 103 104 • The DBMS can first figure out all the tuples that it needs and then sort them based on their page id.

GT 8803 // Fall 2019 73 INDEX SCAN PAGE SORTING

Scan Direction • Retrieving tuples in the order that appear in an unclustered index is inefficient. 101 102 103 104 • The DBMS can first figure out all the tuples that it needs and then sort them based on their page id.

GT 8803 // Fall 2019 74 INDEX SCAN PAGE SORTING

Scan Direction • Retrieving tuples in the order that appear in an unclustered index is inefficient. 101 102 103 104 Page 102 • The DBMS can first figure out Page 103 Page 104 Page 104 all the tuples that it needs Page 102 Page 103 and then sort them Page 102 Page 102 Page 101 based on their page id. Page 103 Page 104 Page 103

GT 8803 // Fall 2019 75 INDEX SCAN PAGE SORTING

Scan Direction • Retrieving tuples in the order that appear in an unclustered index is inefficient. 101 102 103 104 Page 102 • The DBMS can first figure out Page 103 Page 104 Page 104 all the tuples that it needs Page 102 Page 103 and then sort them Page 102 Page 102 Page 101 based on their page id. Page 103 Page 104 Page 103

GT 8803 // Fall 2019 76 INDEX SCAN PAGE SORTING

Scan Direction • Retrieving tuples in the order that appear in an unclustered index is inefficient. 101 102 103 104 Page 102 Page 101 • The DBMS can first figure out Page 103 Page 101 Page 104 Page 102 Page 104 Page 102 all the tuples that it needs Page 102 Page 102 Page 103 Page 102 and then sort them Page 102 Page 103 Page 102 Page 103 Page 101 Page 103 based on their page id. Page 103 Page 104 Page 104 Page 104 Page 103 Page 104

GT 8803 // Fall 2019 77 CLUSTERED VS UNCLUSTERED INDEX

GT 8803 // Fall 2019 78 CLUSTERED VS UNCLUSTERED INDEX

• Q: What is the difference between a clustered and unclustered index? – Clustered: Tuples are stored physically on disk in the same order as the index. Only one per table. – Unclustered: Ordered differently. Values are only pointers to the physical tuples.

GT 8803 // Fall 2019 79 EXPRESSION EVALUATION

GT 8803 // Fall 2018 80 EXPRESSION EVALUATION

SELECT • The DBMS represents a A.id, B.value FROM A, B WHERE clause as an WHERE A.id = B.id expression tree. AND B.val > 100

GT 8803 // Fall 2019 81 EXPRESSION EVALUATION

SELECT • The DBMS represents a A.id, B.value FROM A, B WHERE clause as an WHERE A.id = B.id expression tree. AND B.val > 100

GT 8803 // Fall 2019 82 EXPRESSION EVALUATION

SELECT • The DBMS represents a A.id, B.value FROM A, B WHERE clause as an WHERE A.id = B.id expression tree. AND B.val > 100 AND

= >

Attribute(A.id) Attribute(B.id) Attribute(val) Constant(100)

GT 8803 // Fall 2019 83 EXPRESSION EVALUATION

• The nodes in the tree represent different expression types: – Comparison Operators (=, <, >, !=) – Logical Operators (AND, OR) – Arithmetic Operators (+, -, *, /, %) – Constant Values – Tuple Attribute References

GT 8803 // Fall 2019 84 EXPRESSION EVALUATION

SELECT * FROM B WHERE B.val = ? + 1

GT 8803 // Fall 2018 85 EXPRESSION EVALUATION

SELECT * FROM B WHERE B.val = ? + 1

GT 8803 // Fall 2018 86 EXPRESSION EVALUATION Execution Context SELECT FROM * B Current Tuple Query Parameters Table Schema WHERE B.val = ? + 1 (123, 1000) (int:999) B→(int:id, int:val)

=

Attribute(val) +

Parameter(0) Constant(1)

GT 8803 // Fall 2018 87 EXPRESSION EVALUATION Execution Context SELECT FROM * B Current Tuple Query Parameters Table Schema WHERE B.val = ? + 1 (123, 1000) (int:999) B→(int:id, int:val)

=

Attribute(val) +

Parameter(0) Constant(1)

GT 8803 // Fall 2018 88 EXPRESSION EVALUATION Execution Context SELECT FROM * B Current Tuple Query Parameters Table Schema WHERE B.val = ? + 1 (123, 1000) (int:999) B→(int:id, int:val)

=

Attribute(val) +

Parameter(0) Constant(1)

GT 8803 // Fall 2018 89 EXPRESSION EVALUATION Execution Context SELECT FROM * B Current Tuple Query Parameters Table Schema WHERE B.val = ? + 1 (123, 1000) (int:999) B→(int:id, int:val)

=

Attribute(val) + 1000

Parameter(0) Constant(1)

GT 8803 // Fall 2018 90 EXPRESSION EVALUATION Execution Context SELECT FROM * B Current Tuple Query Parameters Table Schema WHERE B.val = ? + 1 (123, 1000) (int:999) B→(int:id, int:val)

=

Attribute(val) + 1000

Parameter(0) Constant(1)

GT 8803 // Fall 2018 91 EXPRESSION EVALUATION Execution Context SELECT FROM * B Current Tuple Query Parameters Table Schema WHERE B.val = ? + 1 (123, 1000) (int:999) B→(int:id, int:val)

=

Attribute(val) + 1000

Parameter(0) Constant(1)

GT 8803 // Fall 2018 92 EXPRESSION EVALUATION Execution Context SELECT FROM * B Current Tuple Query Parameters Table Schema WHERE B.val = ? + 1 (123, 1000) (int:999) B→(int:id, int:val)

=

Attribute(val) + 1000

Parameter(0) Constant(1) 999 GT 8803 // Fall 2018 93 EXPRESSION EVALUATION Execution Context SELECT FROM * B Current Tuple Query Parameters Table Schema WHERE B.val = ? + 1 (123, 1000) (int:999) B→(int:id, int:val)

=

Attribute(val) + 1000

Parameter(0) Constant(1) 999 GT 8803 // Fall 2018 94 EXPRESSION EVALUATION Execution Context SELECT FROM * B Current Tuple Query Parameters Table Schema WHERE B.val = ? + 1 (123, 1000) (int:999) B→(int:id, int:val)

=

Attribute(val) + 1000

Parameter(0) Constant(1) 999 1 GT 8803 // Fall 2018 95 EXPRESSION EVALUATION Execution Context SELECT FROM * B Current Tuple Query Parameters Table Schema WHERE B.val = ? + 1 (123, 1000) (int:999) B→(int:id, int:val)

= true Attribute(val) + 1000 1000

Parameter(0) Constant(1) 999 1 GT 8803 // Fall 2018 96 TREE VS STRING REPRESENTATION

GT 8803 // Fall 2019 97 TREE VS STRING REPRESENTATION

• Q: Why are queries and expressions represented as a tree as opposed to a string? – Structural elements simplify manipulation as opposed to a string representation – Works well for complex recursive structures (e.g., sub-queries, nested expressions)

GT 8803 // Fall 2019 98 SUMMARY

• The same query plan be executed in multiple ways. • (Most) DBMSs will want to use an index scan as much as possible. • Expression trees are flexible but slow.

GT 8803 // Fall 2019 99 VISUAL QUERY EXECUTION ENGINE

GT 8803 // Fall 2018 100 TABLE

• BLAZEIT – Each table corresponds to a video – Each tuple corresponds to a detected object

Object ID Frame ID Class Mask Features Content

1 1 Bus Mask [F1, F2] Content

– Each table should correspond to an unique entity – Object re-identification

GT 8803 // Fall 2019 101 TABLE

• Prior visual query engines – Assume that data is already populated (i.e., data created externally typically by humans). – In contrast, BLAZEIT automatically populates the data using an off-the-shelf classifier • Late materialization depending on query – Similar to an un-materialized view. – This laziness enables several optimizations

GT 8803 // Fall 2019 102 EARLY VS LATE MATERIALIZATION

• Early materialization is inefficient – Ad-hoc queries: Pre-computing all possible features would be expensive. Wasteful for ad-hoc queries since many of the columns with extracted features may never be used. – Online queries: For queries on live newscasts or broadcast games, it could be faster to execute the queries and classifier directly on the live data.

GT 8803 // Fall 2019 103 QUERY EXAMPLE

• Imagine having to narrow down a video of passing vehicles captured on a traffic camera to red SUVs that are exceeding the speed limit SELECT cameraID, frameID, 풞1(ℱ1(vehBox)) AS vehType, 풞2(ℱ2(vehBox)) AS vehColor FROM (PROCESS inputVideo PRODUCE cameraID, frameID, vehBox USING VehDetector) WHERE vehType=SUV ∧ vehColor=red;

GT 8803 // Fall 2019 104 #1: FILTERING

• To speed up this query, we can train a filtering classifier that drops frames that are unlikely to satisfy the predicate OLD PLAN

NEW PLAN

GT 8803 // Fall 2019 105 #1: FILTERING

• A filtering classifier must be much faster relative to the ML model that it bypasses. – It must filter out a large portion of the input and have few false negatives – Also known as a probabilistic predicate or specialized model

GT 8803 // Fall 2019 106 #1: FILTERING

• Different classifiers are appropriate for different inputs and predicates – Linear SVMs – Deep neural networks • Content-based filtering – Based on low-level visual features (e.g., avg. color) – If an analyst were to query for “red buses”, we could filter the video to have a certain number of red pixels, or a certain level of redness.

GT 8803 // Fall 2019 107 #1: FILTERING

• Temporal filtering – Filtering based on temporal cues – Example: Analyst may want to find buses in the scene for at least K frames. In this case, sub-sample the video at a rate of (K−1)/2. • Spatial filtering – Only regions of interest (ROIs) of the scene are considered. – ROI can be used to train smaller faster models

GT 8803 // Fall 2019 108 #2: SAMPLING

• When the query contains a tolerated error rate, we can sample from the video – Example: User is interested in some statistic over the data, such as average number of cars per frame – Only populate a small number of tuples (or not populate them at all) for faster execution. – In cases where the filtering classifier is accurate enough, we can return the answer directly from the filtering classifier

GT 8803 // Fall 2019 109 #2: SAMPLING

• In a -limited filtering query, user is typically interested in a rare event – Example: A clip containing at least one bus and five cars – Intuition is to bias the search towards regions of the video that likely contain the event – Train a filtering classifier to bias which frames to sample.

GT 8803 // Fall 2019 110 QUERY EXECUTION: SUMMARY

• Key Optimizations – Filtering, Sampling • Query processing model – Tuple-at-a-time • Access methods – Sequential scan with a complex predicate – Index scan: Filtering classifier (e.g., vehType) – Multi-Index scan: Spatial access (e.g., R-trees)

GT 8803 // Fall 2019 111 NEXT LECTURE

• Given an error budget, how to select between different filtering classifiers? – Query optimization

GT 8803 // Fall 2019 112