Presentation is loading. Please wait.

Presentation is loading. Please wait.

Lecture 25: Query Execution

Similar presentations


Presentation on theme: "Lecture 25: Query Execution"— Presentation transcript:

1 Lecture 25: Query Execution
Wednesday, December 1st, 2005

2 Outline Index-based algorithms Query optimization: algebraic laws 16.2

3 Indexed Based Algorithms
Recall that in a clustered index all tuples with the same value of the key are clustered on as few blocks as possible Note: book uses another term: “clustering index”. Difference is minor… a a a a a a a a a a

4 Index Based Selection Selection on equality: sa=v(R)
Clustered index on a: cost B(R)/V(R,a) Unclustered index on a: cost T(R)/V(R,a)

5 Index Based Selection B(R) = 2000 T(R) = 100,000 V(R, a) = 20 Example:
Table scan (assuming R is clustered): B(R) = 2,000 I/Os Index based selection: If index is clustered: B(R)/V(R,a) = 100 I/Os If index is unclustered: T(R)/V(R,a) = 5,000 I/Os Lesson: don’t build unclustered indexes when V(R,a) is small ! cost of sa=v(R) = ?

6 Index Based Join R S Assume S has an index on the join attribute
Iterate over R, for each tuple fetch corresponding tuple(s) from S Assume R is clustered. Cost: If index is clustered: B(R) + T(R)B(S)/V(S,a) If index is unclustered: B(R) + T(R)T(S)/V(S,a)

7 Index Based Join Assume both R and S have a sorted index (B+ tree) on the join attribute Then perform a merge join called zig-zag join Cost: B(R) + B(S)

8 Summary of External Join Algorithms
Block Nested Loop Join: B(S) + B(R)*B(S)/M Partitioned Hash Join: 3B(R)+3B(S) Assuming min(B(R),B(S)) <= M2 Merge Join Assuming B(R)+B(S) <= M2 Index Join B(R) + T(R)B(S)/V(S,a) Assuming…

9 Example Select Product.pname From Product, Company
Product(pname, maker), Company(cname, city) How do we execute this query ? Select Product.pname From Product, Company Where Product.maker=Company.cname and Company.city = “Seattle”

10 Example Product(pname, maker), Company(cname, city) Assume:
Clustered index: Product.pname, Company.cname Unclustered index: Product.maker, Company.city

11 Logical Plan: scity=“Seattle” Product (pname,maker)
maker=cname scity=“Seattle” Product (pname,maker) Company (cname,city)

12 Index-based selection
Physical plan 1: Index-based join Index-based selection cname=maker scity=“Seattle” Company (cname,city) Product (pname,maker)

13 Scan and sort (2a) index scan (2b)
Physical plans 2a and 2b: Merge-join Which one is better ?? maker=cname scity=“Seattle” Product (pname,maker) Company (cname,city) Index- scan Scan and sort (2a) index scan (2b)

14 Index-based selection
Physical plan 1:  T(Product) / V(Product, maker) Index-based join Index-based selection Total cost: T(Company) / V(Company, city)  T(Product) / V(Product, maker) cname=maker scity=“Seattle” Company (cname,city) Product (pname,maker) T(Company) / V(Company, city)

15 Scan and sort (2a) index scan (2b)
Total cost: (2a): 3B(Product) + B(Company) (2b): T(Product) + B(Company) Physical plans 2a and 2b: Merge-join No extra cost (why ?) maker=cname scity=“Seattle” 3B(Product) Product (pname,maker) Company (cname,city) T(Product) Table- scan Scan and sort (2a) index scan (2b) B(Company)

16 Which one is better ?? It depends on the data !!
Plan 1: T(Company)/V(Company,city)  T(Product)/V(Product,maker) Plan 2a: B(Company) + 3B(Product) Plan 2b: B(Company) + T(Product) Which one is better ?? It depends on the data !!

17 Example Case 1: V(Company, city)  T(Company)
T(Company) = 5, B(Company) = M = 100 T(Product) = 100, B(Product) = 1,000 We may assume V(Product, maker)  T(Company) (why ?) Case 1: V(Company, city)  T(Company) Case 2: V(Company, city) << T(Company) V(Company,city) = 2,000 V(Company,city) = 20

18 Which Plan is Best ? Case 1: Case 2:
Plan 1: T(Company)/V(Company,city)  T(Product)/V(Product,maker) Plan 2a: B(Company) + 3B(Product) Plan 2b: B(Company) + T(Product) Case 1: Case 2:

19 Lessons Need to consider several physical plan
even for one, simple logical plan No magic “best” plan: depends on the data In order to make the right choice need to have statistics over the data the B’s, the T’s, the V’s

20 Query Optimzation Have a SQL query Q Create a plan P
Find equivalent plans P = P’ = P’’ = … Choose the “cheapest”. HOW ??

21 Logical Query Plan Q.phone > ‘5430000’ P=  In class:
SELECT P.buyer FROM Purchase P, Person Q WHERE P.buyer=Q.name AND Q.city=‘seattle’ AND Q.phone > ‘ ’ P= buyer City=‘seattle’ phone>’ ’ Buyer=name In class: find a “better” plan P’ Purchase Person

22 Logical Query Plan Q= SELECT city, sum(quantity) FROM sales
GROUP BY city HAVING sum(quantity) < 100 T2(city,p) P= s p < 100 T1(city,p) g city, sum(quantity)→p In class: find a “better” plan P’ sales(product, city, price)

23 The three components of an optimizer
We need three things in an optimizer: Algebraic laws An optimization algorithm A cost estimator

24 Algebraic Laws Commutative and Associative Laws Distributive Laws
R  S = S  R, R  (S  T) = (R  S)  T R || S = S || R, R || (S || T) = (R || S) || T Distributive Laws R || (S  T) = (R || S)  (R || T)

25 Algebraic Laws Laws involving selection:
s C AND C’(R) = s C(s C’(R)) = s C(R) ∩ s C’(R) s C OR C’(R) = s C(R)  s C’(R) s C (R || S) = s C (R) || S When C involves only attributes of R s C (R – S) = s C (R) – S s C (R  S) = s C (R)  s C (S) s C (R || S) = s C (R) || S

26 Algebraic Laws Example: R(A, B, C, D), S(E, F, G)
s F=3 (R || D=E S) = ? s A=5 AND G=9 (R || D=E S) = ?

27 Algebraic Laws Laws involving projections
PM(R || S) = PM(PP(R) || PQ(S)) PM(PN(R)) = PM,N(R) Example R(A,B,C,D), S(E, F, G) PA,B,G(R || D=E S) = P ? (P?(R) || D=E P?(S))

28 Algebraic Laws Laws involving grouping and aggregation:
(A, agg(B)(R)) = A, agg(B)(R) A, agg(B)((R)) = A, agg(B)(R) if agg is “duplicate insensitive” Which of the following are “duplicate insensitive” ? sum, count, avg, min, max A, agg(D)(R(A,B) || B=C S(C,D)) = A, agg(D)(R(A,B) || B=C (C, agg(D)S(C,D)))

29 Optimizations Based on Semijoins
THIS IS ADVANCED STUFF; NOT ON THE FINAL R S = P A1,…,An (R S) Where the schemas are: Input: R(A1,…An), S(B1,…,Bm) Output: T(A1,…,An)

30 Optimizations Based on Semijoins
Semijoins: a bit of theory (see [AHV]) Given a query: A full reducer for Q is a program: Such that no dangling tuples remain in any relation Q :-  ( (R1 |x| R2 |x| |x| Rn )) Ri1 := Ri Rj1 Ri2 := Ri Rj2 Rip := Rip Rjp

31 Optimizations Based on Semijoins
Example: A full reducer is: Q(E) :- R1(A,B) |x| R2(B,C) |x| R3(C,D,E) R2(B,C) := R2(B,C) |x R1(A,B) R3(C,D,E) := R3(C,D,E) |x R2(B,C) R2(B,C) := R2(B,C) |x R3(C,D,E) R1(A,B) := R1(A,B) |x R2(B,C) The new tables have only the tuples necessary to compute Q(E)

32 Optimizations Based on Semijoins
Example: Doesn’t have a full reducer (we can reduce forever) Theorem a query has a full reducer iff it is “acyclic” Q(E) :- R1(A,B) |x| R2(B,C) |x| R3(A,C, E)

33 Optimizations Based on Semijoins
Semijoins in [Chaudhuri’98] CREATE VIEW DepAvgSal As ( SELECT E.did, Avg(E.Sal) AS avgsal FROM Emp E GROUP BY E.did) SELECT E.eid, E.sal FROM Emp E, Dept D, DepAvgSal V WHERE E.did = D.did AND E.did = V.did AND E.age < 30 AND D.budget > 100k AND E.sal > V.avgsal

34 Optimizations Based on Semijoins
First idea: CREATE VIEW LimitedAvgSal As ( SELECT E.did, Avg(E.Sal) AS avgsal FROM Emp E, Dept D WHERE E.did = D.did AND D.buget > 100k GROUP BY E.did) SELECT E.eid, E.sal FROM Emp E, Dept D, LimitedAvgSal V WHERE E.did = D.did AND E.did = V.did AND E.age < 30 AND D.budget > 100k AND E.sal > V.avgsal

35 Optimizations Based on Semijoins
Better: full reducer CREATE VIEW PartialResult AS (SELECT E.id, E.sal, E.did FROM Emp E, Dept D WHERE E.did=D.did AND E.age < 30 AND D.budget > 100k) CREATE VIEW Filter AS (SELECT DISTINCT P.did FROM PartialResult P) CREATE VIEW LimitedAvgSal AS (SELECT E.did, Avg(E.Sal) AS avgsal FROM Emp E, Filter F WHERE E.did = F.did GROUP BY E.did)

36 Optimizations Based on Semijoins
SELECT P.eid, P.sal FROM PartialResult P, LimitedDepAvgSal V WHERE P.did = V.did AND P.sal > V.avgsal


Download ppt "Lecture 25: Query Execution"

Similar presentations


Ads by Google