• 沒有找到結果。

Database Systems (資料庫系統) Chapter 12 Overview of Query Evaluation

N/A
N/A
Protected

Academic year: 2021

Share "Database Systems (資料庫系統) Chapter 12 Overview of Query Evaluation"

Copied!
38
0
0

加載中.... (立即查看全文)

全文

(1)

Database Systems

( 資料庫系統 )

Chapter 12 Overview of Query Evaluation

November 22, 2004

(2)

Announcement

• Assignment #6 is due on 11/24 (Wednesday).

• Next week reading: Chapter 13.

(3)

Cool Ubicomp Project

Passive RFID-grid Indoor Location Systems

for Blind Users (U. of Florida)

(4)

Overview of Query Evaluation

(5)

Outline

• Query evaluation (Overview)

• Relational Operator Evaluation Algorithms (Overview)

• Statistics and Catalogs

• Query Optimization (Overview)

• Example

(6)

Tables

• Sailors(sid, sname, rating, age)

• Reserves(sid, bid, day, rname)

(7)

• Given a SQL query, we would like to find an

efficient plan

(minimal number of disk I/Os) to evaluate it.

• What are general steps of a SQL query evaluation?

• Step 1: a query is translated into a

relational algebra tree

– σ(selection), π (projection), and ⋈ (join)

Overview of Query Evaluation (1)

SELECT S.sname

FROM Reserves R, Sailors S WHERE R.sid=S.sid AND

R.bid=100 AND S.rating>5

sid=sid

bid=100 rating > 5 sname

(8)

Overview of Query Evaluation (2)

• Step 2: Find a good

evaluation plan

(Query

Optimization)

– Estimate costs for several alternative equivalent

evaluation plans.

– Different order of evaluations gives different cost (e.g., push selection (bid=100) before

join) Reserves Sailors

sid=sid

bid=100 rating > 5 sname

(9)

Overview of Query Evaluation (3)

• (continue step 2)

– An evaluation plan is

consisted of choosing access

method & evaluation

algorithm.

– Selecting an

access method

to retrieve records for each

table on the tree (e.g., file

scan, index search, etc.)

– Selecting an

evaluation

algorithm

for each relational

operator on the tree (e.g.,

index nested loop join,

sort-merge join, etc.)

Reserves Sailors

sid=sid

bid=100 rating > 5 sname

(file scan) (file scan) (index nested loop)

(on-the-fly) (on-the-fly)

(10)

Overview of Query Evaluation (4)

• Two main issues in query optimization:

For a given query, what plans are considered?

• Consider a few plans (considering all is too many &

expensive), and find the one with the cheapest (estimated) cost.

How is the cost of a plan estimated?

Examine catalog table that has data schemas and statistics. • There are system-wide factors that can also affect cost, such

(11)

Statistics and Catalogs

• Need information about the relations and indexes involved.

Cat

alogs

typically contain at least:

– # tuples (NTuples) and # pages (NPages) for each table. – # distinct key values (NKeys) and NPages for each index.

– Index height, low/high key values (Low/High) for each tree index.

How are they used to estimate the cost? Consider:

– Reserves ⋈ reserves.sid = sailors.sid Sailors (assume simple nested

loop join)

Foreach tuple r in reserves Foreach tuple s in sailors

If (r.sid = s.sid) then add <r,s> to the results

– Sailors (⋈ σ bid = 10 Reserves) – Sailors (⋈ σ bid > 10 Reserves)

(12)

Statistics and Catalogs

• Catalogs are updated periodically.

Updating whenever lots of data changes; lots of approxi

mation anyway, so slight inconsistency is ok.

• More detailed information (e.g., histograms of the

values in some fields) are sometimes stored.

– They can be used to estimate # tuples matching certain

conditions (bid > 5)

(13)

Relational Operator Evaluation

• There are several alternative algorithms for implementing

each relational operator (selection, projection, join, etc.).

• No algorithm is always better (disk I/O costs) than the

others. It depends on the following factors:

– Sizes of tables involves

– Existing indexes and sort orders

– Size of buffer pool (Buffer replacement policy)

• Describe (1) common techniques for relational operator

algorithms, (2) access path, and (3) details of algorithms.

(14)

Some Common Techniques

• Algorithms for evaluating relational operators use some

simple ideas repeatedly:

– Indexing: If a selection or join condition is specified (e.g., σ

bid = 10 Reserves), use an index (<bid>) to retrieve the tuples

that satisfy the condition.

– Iteration: Sometimes, faster to scan all tuples even if there is an index (σbid ≠ 10 Reserves, bid = 1 .. 1000). And som etimes, we can scan the data entries in an index instead of the table itself. (πbid Reserves).

(15)

Access Paths

• An access path is a method of retrieving tuples.

– Note that every relational operator takes one or two tables as its input.

– There are two possible methods: (1) file scan, or (2) index that m atches a selection condition.

• Can we use an index for a selection condition? How doe

s an index match a selection condition?

– Selection condition can be rewritten into Conjunctive Normal For m (CNF), or a set of terms (conjuncts) connected by ^ (and).

• Example: (rname=‘Joe’) ^ (bid = 5) ^ (sid = 3)

– Intuitively, an index matches conjuncts means that it can be use d to retrieve (just) tuples that satisfy the conjunct.

(16)

Access Paths for Tree Index

• A tree index matches conjuncts that involve only attributes

in a

prefix of its index search key

.

– E.g., Tree index on <a, b, c> matches the selection condition (a= 5 ^ b=3), and (a=5 ^ b>6), but not (b=0).

– Tree index on <a, b, c>: <a0, b0, c0>, <a0, b0, c1>, <a0, b0, c2>, …, <a0, b1, c0>, <a0, b1, c1>, …<a1, b0, c0>, …

– Can match range condition (a=5 ^ b>3).

– How about (a=5 ^ b=3 ^ c=2 ^ d=1)?

– (a=5 ^ b=3 ^ c=2) is called primary conjuncts. Use index to get tup les satisfying primary conjuncts, then check the remaining conditi

(17)

Access Paths for Hash Index

• A hash index matches a conjunct that has a term

attribute = value for every attribute in the search key of

the index.

– E.g., Hash index on <a, b, c> matches (a=5 ^ b=3 ^ c=5), but it does not match (b=3), or (a=5 ^ b=3), or (a>5 ^ b=3 ^ c=5).

• Compare to Tree Index:

– Cannot match range condition.

(18)

A Note on Complex Selections

• Selection conditions are first converted to

conjunctive no

rmal form (CNF):

(day<8/9/94

OR

bid=5

OR

sid=3 )

AND

(rname=‘Paul’

OR

bid=5

OR

sid=3)

• We only discuss case with no ORs; see text if you are cu

(19)

Selectivity of Access Paths

• Selectivity of an access path

is the number of page I/Os

needed to retrieve the tuples satisfying the desired condi

tion.

– Obviously, we want to use the most selective access path (with t he fewest page I/Os).

• Possible access paths for selections:

– Use an index that matches the selection condition. – Scan the file records.

– Scan the index (e.g., πbid Reserves, index on bid)

• Access path using index may not be the most selective!

(20)

Selection

1.

Find the

most selective access path

2.

Retrieve tuples using it

3.

Apply any remaining terms that don’t

match

the index

Consider

σ

day<8/9/94 ^ bid=5 ^ sid=3

.

– A B+ tree index on day can be used; then, (bid=5 ^ sid=3) mus t be checked for each retrieved tuple.

– A hash index on <bid, sid> could be used; day<8/9/94 must th en be checked.

SELECT (*)

FROM Reserves R

(21)

Example

• Use the following example to estimate page I/O cost of diff

erent algorithms.

• Sailors( sid:integer, sname:string, rating:integer, age:real)

– Each Sailor tuple is 50 bytes long

– A page is 4Kbytes. It can hold 80 sailor tuples.

– We have 500 pages of Sailors (total 40,000 sailor tuples).

• Reserves( sid:integer, bid:integer, day:dates, rname:strin

g)

– Each reserve tuple is 40 bytes long

– A page is 4Kbytes. It can hold 100 reserve tuples.

(22)

Reduction Factor & Catalog Stats

• Reduction factor

is the fraction of tuples in the table that

satisfy a given conjunct.

• Example #1:

– Index H on Sailors with search key <bid> – Selection condition (bid=5)

– Stats from Catalog: NKeys(H) = # of distinct key values = 10 – Reduction factor = 1 / NKeys(H) = 1/10

• Examples #2:

– Index on Reserves <bid, sid> (not a key, not stats on them) – Selection condition (bid=5 ^ sid=3)

(23)

More on Reduction Factor

• Examples 3:

– Range condition as (day > 9/1/2002)

– Index Key T on day

– Stats from Catalog: High(T) = highest day value, Low(T) = lowes t day value.

– Reduction factor = (High(T) – value) / (High(T) – Low(T)) – Say: High(T) = 12/31/2002, Low(T) =1/1/2002

(24)

Using an Index for Selections

• Cost depends on

#matched tuples

and

clustering

.

Cost of finding qualifying data entries (typically small) plus cost of r

etrieving records (could be large w/o clustering)

– Why large? Each matched entry could be on a different page.

Assume uniform distribution, 10% of tuples matched (100 pages, 1

0,000 tuples).

• With a clustered index on <rid>, cost is little more than 100 I/Os; • If unclustered, worse case is 10,000 I/Os.

(25)

Projection

• Projection drops columns not in the select attribute list.

• The expensive part is removing duplicates.

• If no duplicate removal,

– Simple iteration through table.

– Given index <sid, bid>, scan the index entries.

• If duplicate removal, use sorting (partitioning)

(1) Scan table to obtain <sid, bid> pairs (2) Sort pairs based on <sid, bid>

(3) Scan the sorted list to remove adjacent duplicates.

SELECT DISTINCT R.sid, R.bid FROM Reserves R

(26)

More on Projection

• Some optimization by combining sorting with projection

(talk more on sorting in Chapter 13)

• Hash-based project:

– Hash on <sid, bid> (#buckets = #buffer pages).

– Load buckets into memory one at a time and eliminate duplicates.

(27)

Join: Index Nested Loops

• There exists an index <sid> for Sailors.

• Index Nested Loops

: Scan R, for each tuple in R, then us

e index to find matching tuple in S.

• Say we have unclustered hash index <sid> in Sailors. Wh

at is the cost of join operation?

– Scan R = 1000 I/Os

– R has 100,000 tuples. For each R tuple, retrieve index page (1.2 I /Os on average for hashing) and data page (1 I/O).

– Total cost = 1,000 + 100,000 *(1.2 + 1) = 221,000 I/Os.

foreach tuple r in R do

foreach tuple s in S where r

.sid

= s

.sid

do

add <r, s> to result

Reserves (R) ⋈ Sailors (S)

(28)

Join: Sort-Merge

• It does not use any index.

• Sort R and S on the join column

• Scan sorted lists to find matches, like a

me

rge

on join column

• Output resulting tuples.

(29)

Example of Sort-Merge Join

• The cost of a merge sort is 2*M log(B-1) M, whereas M = #pages, B = siz

e of buffer.

– B-1 is quite large, so log(B-1) M is generally just 2.

• Total cost = cost of sorting R & S + Cost of merging = 2*2*(1000+500) + (100+500) = 7500 I/Os. (a lot less than index nested loops join!)

sid sname rating age

22 dustin

7

45.0

28 yuppy

9

35.0

31 lubber

8

55.5

44 guppy

5

35.0

58 rusty

10

35.0

sid bid

day

rname

28 103 12/4/96

guppy

28 103 11/3/96

yuppy

31 101 10/10/96

dustin

31 102 10/12/96

lubber

31 101 10/11/96

lubber

58 103 11/12/96

dustin

(30)

Index Nested Loop Join vs.

Sort-Merge Join

• Sort-merge join does not require a pre-existing index, and …

– Performs better than index-nested loop join. – Resulting tuples sorted on sid.

• Index-nested loop join has a nice property:

incremental

.

– The cost proportional to the number of Reserves tuples.

• Cost = #tuples(R) * Cost(accessing index+record)

– Say we have very selective condition on Reserves tuples.

• Additional selection: R.bid=101

• Cost small for index nested loop, but large for sort-merge join (sort Sailor s & merging)

Reserves (R) ⋈ Sailors (S)

(31)

Other Relational Operators

• Discussed simple evaluation algorithms for

– Projection, Selection, and Join

• How about other relational operators?

– Set-union, set-intersection, set-difference, etc.

– The expensive part is duplicate elimination (same as i

n projection).

– How to do R1 U R2 ?

• SQL aggregation (group-by, max, min, etc.)

– Group-by is typically implemented through sorting (wit

hout search index on group-by attribute).

– Aggregation operators are implemented using counter

s as tuples are retrieved.

(32)

Query Optimization

• Find a good plan for an entire query consisting of many

relational operators.

– So far, we have seen evaluation algorithms for each relational operator.

• Query optimization has two basic steps:

– Enumerate alternative plans for evaluating the query

– Estimating the cost of each enumerated plan & choose the one with lowest estimated cost.

• Consult the catalog for estimation.

(33)

Motivating Example

• Cost: 1000+1000*500 I/Os

• Misses several opportunities:

selections could have been

`pushed’ earlier, no use is made

of any available indexes, etc.

• Goal of optimization: To find

more efficient plans that compute

the same answer.

SELECT S.sname

FROM Reserves R, Sailors S WHERE R.sid=S.sid AND

R.bid=100 AND S.rating>5

Reserves Sailors sid=sid bid=100 rating > 5 sname sid=sid bid=100 rating > 5 sname

(Simple Nested Loops) (On-the-fly) (On-the-fly)

RA Tree:

(34)

Pipeline Evaluation

• How to avoid the cost of ph

ysically writing out intermedi

ate results between operato

rs?

– Example: between join and se lection

– Use pipelining, each join tuple (produced by join) is (1) check ed with selection condition, an d (2) projected out on the fly,

sid=sid

bid=100 rating > 5 sname

(Simple Nested Loops) (On-the-fly) (On-the-fly)

(35)

Alternative Plan 1

(No Indexes)

• Main difference: push selects.

• With 5 buffers, cost of plan:

Scan Reserves (1000 pages) for selection + write temp T1 (10 pages, if we

have 100 boats, uniform distribution).

Scan Sailors (500 pages) for selection + write temp T2 (250 pages, if we

have 10 ratings, uniform distribution).

Sort T1 (2*2*10), sort T2 (2*4*250), merge (10+250)

Total: (1000 + 500 + 10 + 250) + (40 + 2000 + 260) = 4060 page I/Os.

• If we used BNL join, join cost = 10+4*250, total cost = 2770. • If we `push’ projection, T1 has only sid, T2 only sid and sname:

– T1 fits in 3 pages, cost of BNL drops to under 250 pages, total < 2000.

Reserves Sailors sid=sid bid=100 sname(On-the-fly) rating > 5 (Scan; write to temp T1) (Scan; write to temp T2) (Sort-Merge Join)

(36)

Alternative Plan 2

With Indexes

• With clustered index on bid of Reserves, we get 100,000/100 = 1000 tuples on 1000/10 0 = 10 pages.

• Use pipelining (the join tuples are not mate

rialized). Reserves Sailors sid=sid bid=100 sname (On-the-fly) rating > 5 (Use hash index; do not write result to temp)

(Index Nested Loops, with pipelining )

(On-the-fly)

• Join column sid is a key for Sailors.

• Projecting out unnecessary fields from Sailors may not help.

– Why not? Need Sailors.sid for join.

(37)

Next 3 Lectures

• External sorting

• Evaluation of relational operators

• Relational query optimizer

(38)

Summary

• There are several alternative evaluation

algorithms for each relational operator.

• A query is evaluated by converting it to a

relational algebra tree and evaluating the

operators in the tree.

• Must understand query optimization in order to

fully understand the performance impact of a

given database design (relations, indexes) on a

workload (set of queries).

參考文獻

相關文件

We investigate some properties related to the generalized Newton method for the Fischer-Burmeister (FB) function over second-order cones, which allows us to reformulate the

代碼 姓名 姓別 住址 電話 部門 部門 位置..

Non-projective Dependency Parsin g using Spanning Tree Algorithm.. R98922004 Yun-Nung Chen 資工碩一

The min-max and the max-min k-split problem are defined similarly except that the objectives are to minimize the maximum subgraph, and to maximize the minimum subgraph respectively..

[18] Jiho Ryu, Hojin Lee, Yongho Seok, Taekyoung Kwon and Yanghee Choi, “A Hybrid Query Tree Protocol for Tag Collision Arbitration in RFID systems,”,

The Performance Evaluation for Horizontal, Vertical and Hybrid Schema in Database Systems.. -A Case Study of Wireless Broadband

Choi, “A Hybrid Query Tree Protocol for Tag Collision Arbitration in RFID systems”, IEEE International Conference on Communications (ICC-07), pp.24–28, 2007. Cole, “THE

In this chapter, the results for each research question based on the data analysis were presented and discussed, including (a) the selection criteria on evaluating