Other Relational Languages: Exercises
Other Relational Languages: Exercises
Other Relational Languages: Exercises
Exercises
5.1 Answer: The participated relation relates car(s) and accidents. Assume the date attribute is of the form YYYY-MM-DD. a. Find the total number of people who owned cars that were involved in accidents in 1989. accident report-number date location report date participated driver-id car report-number damage-amount P.CNT.UNQ.ALL report
conditions date = ( 1989-00-00 and 1989-12-31 ) b. Find the number of accidents in which the cars belonging to John Smith were involved. person driver-id name address driver John Smith participated driver-id car report-number damage-amount driver P.CNT.ALL
25
26
Chapter 5
c. Add a new accident to the database; assume any values for required attributes. We assume that the driver was Williams, although it could have been someone else. Also assume that Williams has only one Toyota. accident report-number date location I. 4007 1997-01-01 Berkeley participated driver-id I. driver car report-number damage-amount license 4007 3000 license license
driver-id name address driver Williams driver-id name address driver John Smith owns driver-id driver license license model Mazda
car D.
license license
year
e. Update the damage amount for the car with license number AABB2000 in the accident with report number AR2197 to $3000. owns driver-id license driver AABB2000 participated driver-id car report-number damage-amount driver AR2197 U.3000 5.3 Answer: a. Find all employees who earn more than the average salary of all employees of their company.
Exercises
27
The following solution assumes that all people work for at most one company. works person-name company-name salary P. y x y z conditions x > AVG.ALL. z b. Find the company that has the most employees. works person-name company-name salary x P.G. y G.
conditions CNT.UNQ. x MAX.CNT.UNQ.ALL. y c. Find the company that has the smallest payroll. works person-name company-name salary P.G. x G. y conditions SUM.ALL. x MIN.SUM.ALL. y d. Find those companies whose employees earn a higher salary, on average, than the average salary at First Bank Corporation. works person-name company-name salary P.G. x First Bank Corporation y
conditions AVG.ALL. x > AVG.ALL. y 5.5 Answer: a. A (r) i. r ii. query (X) :- r (X, Y, Z) b. B = 17 (r) A B P. C
28
Chapter 5
i. r P. A B 17 C
ii. query (X, Y ) :- r (X, V, W ), s (W, Z, Y ) 5.7 Answer: a. {< a > | b (< a, b > r b = 17)} i. r ii. query (X) :- r (X, 17) b. {< a, b, c > | < a, b > r < a, c > s} A B P. 17
Exercises
29
i. r A a A a B b C c
result A B C P. a b c ii. query(X, Y, Z) :- r(X, Y), s(X, Z) c. {< a > | c (< a, c > s b1 , b2 (< a, b1 > r < c, b2 > r b1 > b2 ))} i. r A B a > s c s A P. a C c
ii. query (X) :- s (X, Y ), r (X, Z), r (Y, W ), Z > W 5.8 Answer: a. Find all employees who work (directly or indirectly) under the manager Jones. query (X) :- p (X) p (X) :- manages (X, Jones) p (X) :- manages (X, Y ), p (Y ) b. Find all cities of residence of all employees who work (directly or indirectly) under the manager Jones. query(X, C) :- p(X), employee(X, S, C) p(X) :- manages(X, Jones) p(X) :- manages(X, Y), p(Y) c. Find all pairs of employees who have a (direct or indirect) manager in common. query(X, Y) :- p(X, W), p(Y, W) p(X, Y) :- manages(X, Y) p(X, Y) :- manages(X, Z), p(Z, Y) d. Find all pairs of employees who have a (direct or indirect) manager in common, and are at the same number of levels of supervision below the common manager.
30
Chapter 5
query(X, Y) :- p(X, Y) p(X, Y) :- manages(X, Z), manages(Y, Z) p(X, Y) :- manages(X, V), manages(Y, W), p(V, W) 5.10 Answer: A Datalog rule has two parts, the head and the body. The body is a comma separated list of literals. A positive literal has the form p(t1 , t2 , . . . , tn ) where p is the name of a relation with n attributes, and t1 , t2 , . . . , tn are either constants or variables. A negative literal has the form p(t1 , t2 , . . . , tn ) where p has n attributes. In the case of arithmetic literals, p will be an arithmetic operator like >, = etc. We consider only safe rules; see Section 5.2.4 for the denition of safety of Datalog rules. Further, we assume that every variable that occurs in an arithmetic literal also occurs in a positive non-arithmetic literal. Consider rst a rule without any negative literals. To express the rule as an extended relational-algebra view, we write it as a join of all the relations referred to in the (positive) non-arithmetic literals in the body, followed by a selection. The selection condition is a conjunction obtained as follows. If p1 (X, Y ), p2 (Y, Z) occur in the body, where p1 is of the schema (A, B) and p2 is of the schema (C, D), then p1 .B = p2 .C should belong to the conjunction. The arithmetic literals can then be added to the condition. As an example, the Datalog query query(X, Y) :- works(X, C, S1), works(Y, C, S2), S1 > S2, manages(X, Y) becomes the following relational-algebra expression: E1 = (w1.company-name = w2.company-name w1.salary>w2.salary manages.person-name = w1.person-name manages.manager - name = w2.person-name) (w1 (works) w2 (works) manages) Now suppose the given rule has negative literals. First suppose that there are no constants in the negative literals; recall that all variables in a negative literal must also occur in a positive literal. Let q(X, Y ) be the rst negative literal, and let it be of the schema (E, F ). Let Ei be the relational algebra expression obtained after all positive and arithmetic literals have been handled. To handle this negative literal, we generate the expression Ej = Ei
(A ,A
1
(Ei ) q)
where A1 and A2 are the attribute names of two columns in Ei which correspond to X and Y respectively. Now let us consider constants occurring in a negative literal. Consider a negative literal of the form q(a, b, Y ) where a and b are constants. Then, in the above expression dening Ej we replace q by A1 =aA2 =b (q). Proceeding in a similar fashion, the remaining negative literals are processed, nally resulting in an expression Ew .
Exercises
31
Finally the desired attributes are projected out of the expression. The attributes in Ew corresponding to the variables in the head of the rule become the projection attributes. Thus our example rule nally becomes the view:create view query as w1.person-name, w2.personname (E2 ) If there are multiple rules for the same predicate, the relational-algebra expression dening the view is the union of the expressions corresponding to the individual rules. The above conversion can be extended to handle rules that satisfy some weaker forms of the safety conditions, and where some restricted cases where the variables in arithmetic predicates do not appear in a positive non-arithmetic literal.