Instructor: Mohamed Eltabakh

Slides:



Advertisements
Similar presentations
Ver 1,12/09/2012Kode :CCs 111,sistem basisdataFASILKOM Chapter 2: Relational Model Database System Concepts, 5th Ed. ©Silberschatz, Korth and Sudarshan.
Advertisements

CS4432: Database Systems II Query Operator & Algebraic Expressions 1.
Relational Algebra – Basis for Relational Query Languages Based on presentation by Juliana Freire.
Chapter 2 Relational Model (part II) Hankz Hankui Zhuo
Oct 28, 2003Murali Mani Relational Algebra B term 2004: lecture 10, 11.
©Silberschatz, Korth and Sudarshan3.1Database System Concepts Chapter 3: Relational Model Structure of Relational Databases Relational Algebra Extended.
©Silberschatz, Korth and Sudarshan3.1Database System Concepts Chapter 3: Relational Model Structure of Relational Databases Relational Algebra Tuple Relational.
©Silberschatz, Korth and Sudarshan3.1Database System Concepts Extended Relational-Algebra-Operations Generalized Projection Outer Join Aggregate Functions.
SQL Structured Query Language Meizhen Huang. Content (4.1 – 4.4) Background Parts of SQL Basic Structure Set Operations Aggregate Functions.
SPRING 2004CENG 3521 E-R Diagram for the Banking Enterprise.
Slides adapted from A. Silberschatz et al. Database System Concepts, 5th Ed. SQL - part 2 - Database Management Systems I Alex Coman, Winter 2006.
Instructor: Mohamed Eltabakh
Relational Algebra. Relational Query Languages n Query = “retrieval program” n Language examples: ù Theoretical : 1. Relational Algebra 2. Relational.
Nov 18, 2003Murali Mani Relational Algebra B term 2004: lecture 10, 11.
Relational Model. 2 Structure of Relational Databases Fundamental Relational-Algebra-Operations Additional Relational-Algebra-Operations Extended Relational-Algebra-Operations.
Murali Mani Relational Algebra. Murali Mani What is Relational Algebra? Defines operations (data retrieval) for relational model SQL’s DML (Data Manipulation.
©Silberschatz, Korth and Sudarshan4.1Database System Concepts Chapter 4: SQL Basic Structure Set Operations Aggregate Functions Null Values Nested Subqueries.
Lecture 6 Structured Query Language SQL Lecture 6 Structured Query Language SQL Instructor: Haya Sammaneh.
Relational Algebra Instructor: Mohamed Eltabakh 1.
Database System Concepts, 5 th Ed. ©Silberschatz, Korth and Sudarshan See for conditions on re-usewww.db-book.com Chapter 2: Relational.
Chapter 6: Formal Relational Query Languages. 6.2 Chapter 6: Formal Relational Query Languages Relational Algebra Tuple Relational Calculus Domain Relational.
1 The Relational Model By Elena Ciriani CS157A February 19, 2004 Professor Lee.
CIS552Relational Model1 Structure of Relational Database Relational Algebra Extended Relational-Algebra-Operations Modification of the Database.
CS 370 Database Systems Lecture 11 Relational Algebra.
3.1Database System Concepts Chapter 3: Relational Model Structure of Relational Databases Relational Algebra Tuple Relational Calculus Domain Relational.
Computing & Information Sciences Kansas State University Monday, 08 Sep 2008CIS 560: Database System Concepts Lecture 5 of 42 Monday, 08 September 2008.
Relational Model By Dr.S.Sridhar, Ph.D.(JNUD), RACI(Paris, NICE), RMR(USA), RZFM(Germany) DIRECTOR ARUNAI ENGINEERING COLLEGE TIRUVANNAMALAI.
Yufis Azhar – Teknik Informatika – UMM.  Aggregation function takes a collection of values (of a single attribute) and returns a single value as a result.
Advanced Database Systems By- Jesmin Akhter Assistant Professor, IIT, Jahangirnagar University.
Chapter 2: Relational Model. 2.2 Chapter 2: Relational Model Structure of Relational Databases Fundamental Relational-Algebra-Operations Additional Relational-Algebra-Operations.
Chapter 8: SQL. Data Definition Modification of the Database Basic Query Structure Aggregate Functions.
©Silberschatz, Korth and Sudarshan2.1Database System Concepts - 5 th Edition, Oct 5, 2006 Example.
Chapter 2: Relational Model. 2.2Unite International CollegeDatabase Management Systems Chapter 2: Relational Model Structure of Relational Databases Fundamental.
Chapter 2: Relational Model II Relational Algebra basics Relational Algebra basics.
Computing & Information Sciences Kansas State University Friday, 26 Jan 2008CIS 560: Database System Concepts Lecture 2 of 42 Friday, 29 August 2008 William.
2.1 Chapter 2: Relational Model. 2.2 Chapter 2: Relational Model Structure of Relational Databases Fundamental Relational-Algebra-Operations Additional.
©Silberschatz, Korth and Sudarshan3.1Database System Concepts Chapter 3: Relational Model Structure of Relational Databases Relational Algebra Extended.
Relational Algebra Instructor: Mohamed Eltabakh 1 Part II.
©Silberschatz, Korth and Sudarshan3.1Database System Concepts Extended Relational-Algebra-Operations Generalized Projection Aggregate Functions Outer Join.
Computing & Information Sciences Kansas State University Wednesday, 03 Sep 2008CIS 560: Database System Concepts Lecture 3 of 42 Wednesday, 03 September.
Relational Algebra Instructor: Mohamed Eltabakh 1.
ICOM 5016 – Introduction to Database Systems Lecture 6 Dr. Manuel Rodriguez Department of Electrical and Computer Engineering University of Puerto Rico,
ASET Relational Algebra continues…. ASET Rename Operation Allows us to name, and therefore to refer to, the results of relational-algebra expressions.
Database System Concepts, 5 th Ed. ©Silberschatz, Korth and Sudarshan See for conditions on re-usewww.db-book.com Chapter 2: Relational.
IS 230Lecture 7Slide 1 Relational Algebra Lecture 8 Text Book – Chapter.
Chapter 3: Relational Model III Additional Relational Algebra Operations Additional Relational Algebra Operations Views Views.
Relational Algebra Instructor: Mohamed Eltabakh 1.
PMIT-6102 Advanced Database Systems By- Jesmin Akhter Assistant Professor, IIT, Jahangirnagar University.
Query Languages Language in which user requests information from the database. Categories of languages Procedural Non-procedural, or declarative “Pure”
Database System Concepts, 6 th Ed. ©Silberschatz, Korth and Sudarshan See for conditions on re-usewww.db-book.com Chapter 6: Formal Relational.
Database System Concepts, 6 th Ed. ©Silberschatz, Korth and Sudarshan See for conditions on re-usewww.db-book.com Chapter 6: Formal Relational.
Midlands State University Topic: Relational DB Model
Module 2: Intro to Relational Model
Relational Model By Dr.S.Sridhar, Ph.D.(JNUD), RACI(Paris, NICE), RMR(USA), RZFM(Germany)
Relational Algebra - Part 1
Chapter 3: Relational Model III
Chapter 2: Intro to Relational Model
Chapter 2: Intro to Relational Model
Chapter 2: Relational Model
Lecture 4 of 42 Relational Joins Wednesday, 30 January 2008
The Relational Algebra and Relational Calculus
SQL: Structured Query Language
Relational Algebra.
Chapter 2: Intro to Relational Model
SQL: Structured Query Language
Chapter 2: Relational Model
Example of a Relation attributes (or columns) tuples (or rows)
Chapter 2: Intro to Relational Model
Relational Model B.Ramamurthy 5/28/2019 B.Ramamurthy.
CS 405G: Introduction to Database Systems
Presentation transcript:

Instructor: Mohamed Eltabakh meltabakh@cs.wpi.edu Relational Algebra Instructor: Mohamed Eltabakh meltabakh@cs.wpi.edu

We learn next how to query the data What we learned so far… Entity-Relationship Model Converting it to relational model Relational Model Creating table Defining constraints Inserting, deleting, and updating data We learn next how to query the data

Query Language Query Language Define data retrieval operations for relational model Express easy access to large data sets in high-level language, not complex application programs Categories of languages Procedural: What you want and how to get it Non-procedural, or declarative: What you want (without how) SQL: High-level language for relational algebra. Relational Algebra : Operator semantics based on set or bag theory Relational algebra form underlying basis (and optimization rules) for SQL

Relational Algebra Basic operators Set Operations (Union: ∪, Intersection: ∩ ,difference: – ) Select: σ Project: π Cartesian product: x rename: ρ More advanced operators, e.g., grouping and joins The operators take one or two relations as inputs and produce a new relation as an output One input  unary operator, two inputs binary operator

Relational Algebra Allows to build expressions using composition of the available operators For example, arithmetic expressions are expressions of operators (w + t) / ((x + y) * 3) In relational algebra, instead of variables we have relations

Set Operators Union, Intersection, Difference Defined only for union compatible relations Relations are union compatible iff they have same sets of attributes (schema), and the same types (domains) of attributes Example : Union compatible or not? Student (sNumber, sName) Course (cNumber, cName) Not compatible

Union over sets:  Consider two relations R and S that are union-compatible R S R  S A B 1 2 3 4 5 6 A B 1 2 3 4 A B 1 2 3 4 5 6

Union over sets:  Notation: R ∪ S Defined as: R ∪S = {t | t∈R or t∈S} For R ∪S to be valid, they have to be union-compatible

Difference over sets: - R – S are the tuples that appear in R and not in S Defined as: R – S = {t | t ∈R and t∈ S} R S R – S A B 1 2 3 4 A B 1 2 5 6 A B 3 4

Intersection over sets: ∩ Consider two Relations R and S that are union-compatible R S R ∩ S A B 1 2 3 4 A B 1 2 3 4 5 6 A B 1 2 3 4

Intersection: ∩ Notation: R ∩ S Defined as: Note: R ∩ S = R– (R–S) R ∩ S = { t | t ∈ r and t ∈ s } Note: R ∩ S = R– (R–S) R S

Selection: σ Select: σc (R): c is a condition on R’s attributes Select subset of tuples from R that satisfy selection condition c σ(C ≥ 6) (R) R A B C 1 2 5 3 4 6 7 A B C 3 4 6 1 2 7

Selection: σ Notation: σc(R) c is called the selection predicate Defined as: σc(R) = {t | t ∈ R and c(t) is true} c is a formula in propositional calculus consisting of terms connected by : ∧ (and), ∨ (or), ¬ (not) Each term is one of: <attribute> op <attribute> | <attribute> op <constant> op is one of: =,≠,>,≥.<.≤ Example of selection: σ branch_name=“Perryridge” ^ balance>1000 (account)

Selection: Example R σ ((A=B) ^ (D>5)) (R)

Project: π πA, C (R) R A1, A2, …, An are called Projection List πA1, A2, …, An (R), with A1, A2, …, An  attributes AR returns all tuples in R, but only columns A1, A2, …, An A1, A2, …, An are called Projection List πA, C (R) R A B C 1 2 5 3 4 6 7 8 A C 1 5 3 6 7 8

Cross Product (Cartesian Product): X R X S S R

Cross Product (Cartesian Product): X Notation R x S Defined as: R x S = {t q | t ∈ r and q ∈ s} Assume that attributes are all unique, otherwise renaming must be used

Renaming: ρ ρS (R) changes relation name from R to S ρS(A1, A2, …, An) (R) renames also attributes of R to A1, A2, …, An ρS (R) ρS(B->X, C, D) (R) R S S B C D 2 3 10 11 6 7 12 B C D 2 3 10 11 6 7 12 X C D 2 3 10 11 6 7 12

Composition of Operations Can build expressions using multiple operations Example: σA=C(R x S) R X S S R σA=C(R x S)

Banking Example branch (branch_name, branch_city, assets) customer (customer_name, customer_street, customer_city) account (account_number, branch_name, balance) loan (loan_number, branch_name, amount) depositor (customer_name, account_number) borrower (customer_name, loan_number)

Example Queries

Example Queries (Cont’d)

Example Queries (Cont’d)

Example Queries (Cont’d)

Example Queries (Cont’d)

More Operators

What We Covered So Far… Set Operations (Union: ∪, Intersection: ∩ ,difference: – ) Select: σ Project: π Cartesian product: x rename: ρ

Example Queries Find customers who have neither accounts nor loans πcustomer_name(customer) - (πcustomer_name(borrower) U πcustomer_name(depositer))

Natural Join: R ⋈ S (Join on the common attributes) Consider relations R with attributes AR, and S with attributes AS. Let A = AR ∩ AS = {A1, A2, …, An} – The common attributes In English Natural join R ⋈ S is a Cartesian Product R X S with equality predicates on the common attributes (Set A)

Natural Join: R ⋈ S R ⋈ S can be defined as : πAR – A, A, AS - A (σR.A1 = S.A1 AND R.A2 = S.A2 AND … R.An = S.An (R X S)) Project the union of all attributes Equality on common attributes Cartesian Product Common attributes appear once in the result

Natural Join: R ⋈ S: Example

Theta Join: R ⋈C S Theta Join is cross product, with condition C It is defined as : R ⋈C S = (σC (R X S)) Theta join can express both Cartesian Product & Natural Join R S A B 1 2 3 D C 2 3 4 5 R ⋈ R.A>=S.CS A B D C 3 2

Example Queries Find customer names having account balance below 100 or above 10,000 πcustomer_name (depositor ⋈ πaccount_number(σbalance <100 OR balance > 10,000 (account)))

Assignment Operator:  The assignment operation (←) provides a convenient way to express complex queries on multiple line Write query as a sequence of line consisting of: Series of assignments Result expression containing the final answer Assignment must always be made to a temporary relation variable May use a variable multiple times in subsequent expressions Example: R1  (σ ((A=B) ^ (D>5)) (R – S)) ∩ W R2  R1 ⋈(R.A = T.C) T Result  R1 U R2

Example Queries Find customers having account balance below 100 and loans above 10,000 R1  πcustomer_name (depositor ⋈ πaccount_number(σbalance <100 (account))) R2  πcustomer_name (borrower ⋈ πloan_number(σamount >10,000 (loan))) Result  R1 ∩ R2

More Relational Operators

Outer Join An extension of the join operation that avoids loss of information Computes the join and then adds tuples form one relation that does not match tuples in the other relation to the result Uses null values to fill in empty attributes with no matching Types of outer join between R and S Left outer (R o⋈ S): preserve all tuples from the left relation R Right outer (R ⋈o S): preserve all tuples from the right relation S Full outer (R ⋈ S): preserve all tuples from both relations o

Left Outer Join (R o⋈ S): Example R ⋈ S (R o⋈ S)

Right Outer Join (R ⋈o S): Example R ⋈ S (R ⋈o S)

Full Outer Join (R ⋈ S): Example

Duplicate Elimination:  (R) Delete all duplicate records Convert a bag to a set R  (R) A B 1 2 3 4 A B 1 2 3 4

Extended Projection: πL (R) Standard project L contains only column names of R Extended projection L may contain expressions and assignment operators π C, VA, X C*3+D (R)

Grouping & Aggregation operator:  Aggregation function takes a collection of values and returns a single value as a result avg: average value min: minimum value max: maximum value sum: sum of values count: number of values Grouing & Aggregate operation in relational algebra g1,g2, …gm, F1(A1), F2(A2), …Fn(An) (R) R is a relation or any relational-algebra expression g1, g2, …gm is a list of attributes on which to group (can be empty) Each Fi is an aggregate function applied on attribute Ai within each group

Grouping & Aggregation Operator: Example S R branch_name,sum(balance)(S) sum(c)(R)

Summary of Relational-Algebra Operators Set operators Union, Intersection, Difference Selection & Projection & Extended Projection Joins Natural, Theta, Outer join Rename & Assignment Duplicate elimination Grouping & Aggregation

Example Queries Find customer names having loans with sum > 20,000 πcustomer_name (σsum > 20,000 (customer_name, sum  sum(amount)(loan ⋈ borrower)))

Example Queries Find the branch name with the largest number of accounts R1  branch_name, countAccounts  count(account_number)(account) R2  Max  max(countAccounts)(R1) Result  πbranch_name(R1 ⋈countAccounts = Max R2)

Example Queries Find account numbers and balances for customers having loans > 10,000 πaccount_number, balance ( (depositor ⋈ account) ⋈ (πcustomer_name (borrower ⋈ (σamount >10,000 (loan)))) )

Reversed Queries (what does it do)? πcustomer_name(customer) - πcustomer_name(borrower) Find customers who did not take loans

Reversed Queries (what does it do)? R1  (MaxLoan  max(amount)(σbranch_name= “ABC” (loan))) Result  πcustomer_name(borrower ⋈ (R1 ⋈MaxLoan=amount^branch_name= “ABC” loan)) Find customer name with the largest loan from a branch “ABC”

Exercise 1 For branches that gave loans > 100,000 or hold accounts with balances >50,000, report the branch name

Exercise 2 Find customer name with the largest loan from a branch in “NY” city