Relational Algebra – Part 2

Slides:



Advertisements
Similar presentations
Relational Database Operators
Advertisements

พีชคณิตแบบสัมพันธ์ (Relational Algebra) บทที่ 3 อ. ดร. ชุรี เตชะวุฒิ CS (204)321 ระบบฐานข้อมูล 1 (Database System I)
IS698: Database Management Min Song IS NJIT. The Relational Data Model.
Relational Algebra, Join and QBE Yong Choi School of Business CSUB, Bakersfield.
Ver 1,12/09/2012Kode :CCs 111,sistem basisdataFASILKOM Chapter 2: Relational Model Database System Concepts, 5th Ed. ©Silberschatz, Korth and Sudarshan.
The Relational Algebra
Relational Algebra Ch. 7.4 – 7.6 John Ortiz. Lecture 4Relational Algebra2 Relational Query Languages  Query languages: allow manipulation and retrieval.
The Relational Database Model
Relational Algebra 1 Chapter 5.1 V3.0 Napier University Dr Gordon Russell.
Database Systems Chapter 6 ITM Relational Algebra The basic set of operations for the relational model is the relational algebra. –enable the specification.
Relational Algebra Relational Calculus. Relational Algebra Operators Relational algebra defines the theoretical way of manipulating table contents using.
Copyright © 2011 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 6 The Relational Algebra and Relational Calculus.
Databases Illuminated
Relational Model & Relational Algebra. 2 Relational Model u Terminology of relational model. u How tables are used to represent data. u Connection between.
Chapter 3 Section 3.4 Relational Database Operators
CS609 Introduction. Databases Current state? Future?
CHAPTER 2 RELATIONAL DATA MODEL. DEFINITION OF DATABASE Shared collection of logically related data (and a description of this data), designed to meet.
DBSQL 3-1 Copyright © Genetic Computer School 2009 Chapter 3 Relational Database Model.
Chapter 2 Adapted from Silberschatz, et al. CHECK SLIDE 16.
M Taimoor Khan Course Objectives 1) Basic Concepts 2) Tools 3) Database architecture and design 4) Flow of data (DFDs)
Relational Algebra - Chapter (7th ed )
Copyright © 2007 Ramez Elmasri and Shamkant B. Navathe Chapter 6 The Relational Algebra.
CSE314 Database Systems The Relational Algebra and Relational Calculus Doç. Dr. Mehmet Göktürk src: Elmasri & Navanthe 6E Pearson Ed Slide Set.
1 The Relational Database Model. 2 Learning Objectives Terminology of relational model. How tables are used to represent data. Connection between mathematical.
M Taimoor Khan Course Objectives 1) Basic Concepts 2) Tools 3) Database architecture and design 4) Flow of data (DFDs)
9/7/2012ISC329 Isabelle Bichindaritz1 The Relational Database Model.
Relational Algebra (Chapter 7)
3 1 Chapter 3 The Relational Database Model Database Systems: Design, Implementation, and Management, Sixth Edition, Rob and Coronel.
Relational Algebra  Souhad M. Daraghma. Relational Query Languages Query languages: Allow manipulation and retrieval of data from a database. Relational.
Relational Model By Dr.S.Sridhar, Ph.D.(JNUD), RACI(Paris, NICE), RMR(USA), RZFM(Germany) DIRECTOR ARUNAI ENGINEERING COLLEGE TIRUVANNAMALAI.
Module Coordinator Tan Szu Tak School of Information and Communication Technology, Politeknik Brunei Semester
From Relational Algebra to SQL CS 157B Enrique Tang.
Chapter 6 The Relational Algebra Copyright © 2004 Ramez Elmasri and Shamkant Navathe.
Slide 6- 1 CARTESIAN (or cross) Product Operation Defines a relation Q that is the concatenation of every tuple of relation R with every tuple of relation.
Database Systems (Atzeni, Ceri, Paraboschi, Torlone) Chapter 3 : Relational algebra and calculus McGraw-Hill and Atzeni, Ceri, Paraboschi, Torlone 1999.
Copyright © 2011 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 6 Part a The Relational Algebra and Relational Calculus Hours 1,2.
Copyright © 2011 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Chapter 6 The Relational Algebra and Relational Calculus.
Relational Algebra MBAD 613 R. Nakatsu. Relational Data Manipulation Language Query-by-Example; Query-by-Form Transform-Oriented Languages Relational.
Advanced Relational Algebra & SQL (Part1 )
1 CS 430 Database Theory Winter 2005 Lecture 5: Relational Algebra.
Dr. Mohamed Hegazi1 The Relational Algebra and Relational Calculus.
Riyadh Philanthropic Society For Science Prince Sultan College For Woman Dept. of Computer & Information Sciences CS 340 Introduction to Database Systems.
3 1 Database Systems The Relational Database Model.
Query Processing – Implementing Set Operations and Joins Chap. 19.
CHAPTER 2 : RELATIONAL DATA MODEL Prepared by : nbs.
Chapter 3 The Relational Model. Objectives u Terminology of relational model. u How tables are used to represent data. u Connection between mathematical.
Week 2 Lecture The Relational Database Model Samuel ConnSamuel Conn, Faculty Suggestions for using the Lecture Slides.
Database Management Systems 3ed, R. Ramakrishnan and J. Gehrke1 Relational Algebra Chapter 4, Part A.
LECTURE THREE RELATIONAL ALGEBRA 11. Objectives  Meaning of the term relational completeness.  How to form queries in relational algebra. 22Relational.
Relational Algebra COMP3211 Advanced Databases Nicholas Gibbins
Chapter 71 The Relational Data Model, Relational Constraints & The Relational Algebra.
The Relational Data Model & Relational Algebra
Ritu CHaturvedi Some figures are adapted from T. COnnolly
CSE202 Database Management Systems
Database Systems Chapter 6
Chapter (6) The Relational Algebra and Relational Calculus Objectives
Relational Algebra Database Management Systems, 3rd ed., Ramakrishnan and Gehrke, Chapter 4.
COMP3017 Advanced Databases
Fundamental of Database Systems
An Algebraic Query Language
Relational Algebra - Part 1
Quiz Questions Q.1 An entity set that does not have sufficient attributes to form a primary key is a (A) strong entity set. (B) weak entity set. (C) simple.
Chapter 4 The Relational Algebra and Calculus
Chapter 3 The Relational Database Model
The Relational Algebra and Relational Calculus
376a. Database Design Dept. of Computer Science Vassar College
Instructor: Mohamed Eltabakh
Data Manipulation using Relational Algebra
Database Dr. Roueida Mohammed.
Presentation transcript:

Relational Algebra – Part 2 Much of the material presented in these slides was developed by Dr. Ramon Lawrence at the University of Iowa

Relational Algebra Operators Relational Operators: Selection σ Projection Π Cartesian product x Join Union  Difference - Intersection ∩ Division  Summarize Note that relational algebra is the foundation of ALL relational database systems. SQL gets translated into relational algebra.

Relational Algebra Operators

Cartesian Product The Cartesian product of two relations R (of degree k1) and S (of degree k2) is: R x S = {t | t [A1,…,Ak1]  R and t [Ak1+1,…,Ak1+k2]  S} The result of R x S is a relation of degree (k1 + k2) and consists of all (k1 + k2)-tuples where each tuple is a concatenation of one tuple of R with one tuple of S. The cardinality of R x S is |R| * |S|. The Cartesian product is also known as cross product.

Cartesian Product Example

θ -Join Theta (θ) join is a derivative of the Cartesian product. Instead of taking all combinations of tuples from R and S, we only take a subset of those tuples that match a given condition F: R F S = {t | t [A1,…,Ak1]  R and t [Ak1+1 ,…,Ak1+k2]  S and F(t) is true} where R, S are relations, t is any tuple F(t) is a formula defined as that of selection. Note that R F S = σF(R × S).

θ -Join Example

Types of Joins The θ-Join is a general join in that it allows any expression in the condition F. However, there are more specialized joins that are frequently used. A equijoin only contains the equality operator (=) in formula F. e.g. WorksOn WorksOn.pno = Proj.pno Proj A natural join over two relations R and S denoted by R * S is the equijoin of R and S over a set of attributes common to both R and S. It removes the “extra copies” of the join attributes. Normally assumes the attributes have the same name in both relations.

Equijoin Example

Natural join Example

Join Practice Questions

Outer Joins Outer joins are used in cases where performing a join "loses“ some tuples of the relations. These are called dangling tuples. There are three types of outer joins: Left outer join – R S - The output contains all tuples of R that match with tuples of S. If there is a tuple in R that matches with no tuple in S, the tuple is included in the final result and is padded with nulls for the attributes of S. Right outer join - R S - The output contains all tuples of S that match with tuples of R. If there is a tuple in S that matches with no tuple in R, the tuple is included in the final result and is padded with nulls for the attributes of R. Full outer join – R S - All tuples of R and S are included in the result whether or not they have a matching tuple in the other relation.

Outer Join Operators Full outer join Left Outer Join Right Outer Join Outer join matching: - join columns, not all columns as in traditional set operators - One-sided outer join: preserving non matching rows of a designated table (left or right) - Full outer join: preserving non matching rows of both tables - See outer join animation for interactive demonstration Unmatched rows of the left table Matched rows using the join condition Unmatched rows of the right table

Right Outer Join Example

Division Operator The division operator on relations R and S, denoted as R ÷ S produces a relation that consists of the set of tuples from R defined over the attributes C that match the combination of every tuple in S, where C is the set of attributes that are in R but not in S. For the division operation to be defined the set of attributes of S must be a subset of the attributes of R. The division operator is used when you want to determine if all combinations of a relationship are present. E.g. Return the list of employees who work on all the projects that 'John Smith' works on. Note that R ÷ S = ΠR-S(R)−ΠR-S ((ΠR-S (R)×S)− R).

Division Example

Division Operation – Example 2 Relations R, S: A B B      1 2 3 4 6 1 2 S R  S: A R  

A Third Division Example Relations R, S: A B C D E D E    a    a b 1 3 a b 1 S R R  S: A B C   a 

Operator Precedence Just like mathematical operators, the relational operators have precedence. The precedence of operators from highest to lowest is: unary operators - σ, Π Cartesian product and joins - x, *, intersection, division - ∩, ÷ union and set difference - , - Parentheses can be used to changed the order of operations.

Complete Set of Relational Algebra Operators It has been shown that the relational operators {σ, Π, ×, , -} form a complete set of operators. That is, any of the other operators can be derived from a combination of these 5 basic operators. Examples: Intersection - R ∩ S ≡ R  S − ((R - S)  (S - R)) We have also seen how a join is a combination of a Cartesian product followed by a selection. Division operator: R(Z) ÷ S(X) where X Z and Y = Z - X: T1 ← ΠY(R) T2 ← ΠY((S × T1) -R) T ← T1 - T2

Conclusion The relational model represents data as relations which are sets of tuples. Each relational schema consists of a set of attribute names which represent a domain. The relational model has several forms of constraints to guarantee data integrity including: domain, entity integrity and referential integrity constraints Keys are used to uniquely identify tuples in relations. Relational algebra is a set of operations for answering queries on data stored in the relational model. The 5 basic relational operators are: {σ, Π, ×, , -}. By combining relational operators, queries can be answered over the base relations.