Module#3
Module#3
Algebra
attributes
(or columns)
tuples
(or rows)
Database System Concepts - 7th Edition 7.11 ©Silberschatz, Korth and Sudarshan
Relation Schema and Instance
Example:
instructor = (ID, name, dept_name, salary)
A relation instance r defined over schema R is denoted by r (R).
The current values a relation are specified by a table
An element t of relation r is called a tuple and is represented by
a row in a table
Database System Concepts - 7th Edition 7.12 ©Silberschatz, Korth and Sudarshan
Attributes
The set of allowed values for each attribute is called the domain of the
attribute
Attribute values are (normally) required to be atomic; that is, indivisible
The special value null is a member of every domain. Indicated that the
value is “unknown”
The null value causes complications in the definition of many operations
Database System Concepts - 7th Edition 7.13 ©Silberschatz, Korth and Sudarshan
Relations are Unordered
Database System Concepts - 7th Edition 7.14 ©Silberschatz, Korth and Sudarshan
Database Schema
Database System Concepts - 7th Edition 7.15 ©Silberschatz, Korth and Sudarshan
Keys
Let K R
K is a superkey of R if values for K are sufficient to identify a unique tuple
of each possible relation r(R)
Example: {ID} and {ID,name} are both superkeys of instructor.
Superkey K is a candidate key if K is minimal
Example: {ID} is a candidate key for Instructor
One of the candidate keys is selected to be the primary key.
Which one?
Foreign key constraint: Value in one relation must appear in another
Referencing relation
Referenced relation
Example: dept_name in instructor is a foreign key from instructor
referencing department
Database System Concepts - 7th Edition 7.16 ©Silberschatz, Korth and Sudarshan
Relational Algebra
A procedural language consisting of a set of operations that take one or
two relations as input and produce a new relation as their result.
Six basic operators
select:
project:
union:
set difference: –
Cartesian product: x
Database System Concepts - 7th Edition 7.17 ©Silberschatz, Korth and Sudarshan
Select Operation
dept_name=“Physics” (instructor)
Result
Database System Concepts - 7th Edition 7.18 ©Silberschatz, Korth and Sudarshan
Select Operation (Cont.)
Database System Concepts - 7th Edition 7.19 ©Silberschatz, Korth and Sudarshan
Project Operation
A unary operation that returns its argument relation, with certain attributes
left out.
Notation:
Database System Concepts - 7th Edition 7.20 ©Silberschatz, Korth and Sudarshan
Project Operation Example
Example: eliminate the dept_name attribute of instructor
Query:
ID, name, salary (instructor)
Result:
Database System Concepts - 7th Edition 7.21 ©Silberschatz, Korth and Sudarshan
Composition of Relational Operations
Database System Concepts - 7th Edition 7.22 ©Silberschatz, Korth and Sudarshan
Cartesian-Product Operation
The Cartesian-product operation (denoted by X) allows us to combine
information from any two relations.
Example: the Cartesian product of the relations instructor and teaches is
written as:
instructor X teaches
We construct a tuple of the result out of each possible pair of tuples: one
from the instructor relation and one from the teaches relation (see next
slide)
Since the instructor ID appears in both relations we distinguish between
these attribute by attaching to the attribute the name of the relation from
which the attribute originally came.
instructor.ID
teaches.ID
Database System Concepts - 7th Edition 7.23 ©Silberschatz, Korth and Sudarshan
The instructor X teaches table
Database System Concepts - 7th Edition 7.24 ©Silberschatz, Korth and Sudarshan
Join Operation
The Cartesian-Product
instructor X teaches
associates every tuple of instructor with every tuple of teaches.
Most of the resulting rows have information about instructors who did
NOT teach a particular course.
To get only those tuples of “instructor X teaches “ that pertain to
instructors and the courses that they taught, we write:
instructor.id = teaches.id (instructor x teaches ))
Database System Concepts - 7th Edition 7.25 ©Silberschatz, Korth and Sudarshan
Join Operation (Cont.)
The table corresponding to:
instructor.id = teaches.id (instructor x teaches))
Database System Concepts - 7th Edition 7.26 ©Silberschatz, Korth and Sudarshan
Join Operation (Cont.)
Thus
instructor.id = teaches.id (instructor x teaches ))
Database System Concepts - 7th Edition 7.27 ©Silberschatz, Korth and Sudarshan
Union Operation
Database System Concepts - 7th Edition 7.28 ©Silberschatz, Korth and Sudarshan
Union Operation (Cont.)
Result of:
course_id ( semester=“Fall” Λ year=2017 (section))
course_id ( semester=“Spring” Λ year=2018 (section))
Database System Concepts - 7th Edition 7.29 ©Silberschatz, Korth and Sudarshan
Set-Intersection Operation
The set-intersection operation allows us to find tuples that are in both
the input relations.
Notation: r s
Assume:
r, s have the same arity
attributes of r and s are compatible
Example: Find the set of all courses taught in both the Fall 2017 and the
Spring 2018 semesters.
course_id ( semester=“Fall” Λ year=2017 (section))
course_id ( semester=“Spring” Λ year=2018 (section))
Result
Database System Concepts - 7th Edition 7.30 ©Silberschatz, Korth and Sudarshan
Set Difference Operation
The set-difference operation allows us to find tuples that are in one relation
but are not in another.
Notation r – s
Set differences must be taken between compatible relations.
r and s must have the same arity
attribute domains of r and s must be compatible
Example: to find all courses taught in the Fall 2017 semester, but not in the
Spring 2018 semester
course_id ( semester=“Fall” Λ year=2017 (section)) −
course_id ( semester=“Spring” Λ year=2018 (section))
Database System Concepts - 7th Edition 7.31 ©Silberschatz, Korth and Sudarshan
The Assignment Operation
It is convenient at times to write a relational-algebra expression by
assigning parts of it to temporary relation variables.
The assignment operation is denoted by and works like assignment in
a programming language.
Example: Find all instructor in the “Physics” and Music department.
Database System Concepts - 7th Edition 7.32 ©Silberschatz, Korth and Sudarshan
The Rename Operation
The results of relational-algebra expressions do not have a name that we
can use to refer to them. The rename operator, , is provided for that
purpose
The expression:
x (E)
returns the result of expression E under the name x
Another form of the rename operation:
x(A1,A2, .. An) (E)
Database System Concepts - 7th Edition 7.33 ©Silberschatz, Korth and Sudarshan
Equivalent Queries
Query 2
dept_name=“Physics” ( salary > 90.000 (instructor))
The two queries are not identical; they are, however, equivalent -- they
give the same result on any database.
Database System Concepts - 7th Edition 7.34 ©Silberschatz, Korth and Sudarshan
Equivalent Queries
Query 2
(dept_name=“Physics” (instructor)) instructor.ID = teaches.ID teaches
The two queries are not identical; they are, however, equivalent -- they
give the same result on any database.
Database System Concepts - 7th Edition 7.35 ©Silberschatz, Korth and Sudarshan
End of Chapter 3
Database System Concepts - 7th Edition 7.36 ©Silberschatz, Korth and Sudarshan