Prerequisite – Relational Algebra

**Project operation** selects (or chooses) certain attributes discarding other attributes. The Project operation is also known as vertical partitioning since it partitions the relation or table vertically discarding other columns or attributes.

**Notation:**

π_{A}(R)

where ‘A’ is the attribute list, it is the desired set of attributes from the attributes of relation(R),

symbol ‘π(pi)’ is used to denote the Project operator,

R is generally a relational algebra expression, which results in a relation.

**Example –**

π_{Age}(Student)

π_{Dept, Sex}(Emp)

**Example –**

Given a relation Faculty (Class, Dept, Position) with the following tuples:

Class | Dept | Position |
---|---|---|

5 | CSE | Assistant Professor |

5 | CSE | Assistant Professor |

6 | EE | Assistant Professor |

6 | EE | Assistant Professor |

**1. Project Class and Dept from Faculty –**

π_{Class, Dept}(Faculty)

Class | Dept |
---|---|

5 | CSE |

6 | EE |

Here, we can observe that the degree (number of attributes) of resulting relation is 2, whereas the degree of Faculty relation is 3, So from this we can conclude that we may get a relation with varying degree on applying Project operation on a relation.

Hence, the degree of resulting relation is equal to the number of attribute in the attribute list ‘A’.

**2. Project Position from Faculty –**

π_{Position}(Faculty)

Position |
---|

Assistant Professor |

Here, we can observe that all the duplicate tuples are removed from the relation in the resulting relation. This is called as Duplicate elimination.

**3. Project Class from Faculty –**

π_{Class}(Faculty)

Class |
---|

5 |

6 |

**Important points:**

- The Project operation removes duplicate tuples.
- The Project operation is not commutative, that is :
π

_{Attribute List 1}(π_{Attribute List2}(R)) != π_{Attribute List 2 }(π_{Attribute List1}(R)) - The following expression is valid only if Attribute List 1 is a subset of Attribute List 2.
π

_{Attribute List 1}(π_{Attribute List2}(R))Moreover, writing the above expression is as good as writing the expression below:

π

_{Attribute List 1}(π_{Attribute List2}(R)) = π_{Attribute List 1 }(R) - The cardinality (number of tuples) of resulting relation from a Project operation is:
1 <= π

_{A}(R) <= |R| - The degree (number of attributes) of resulting relation from a Project operation is equal to the number of attribute in the attribute list ‘A’.
- In SQL, SELECT DISTINCT query is exactly as same as PROJECT here.

Attention reader! Don’t stop learning now. Get hold of all the important CS Theory concepts for SDE interviews with the CS Theory Course at a student-friendly price and become industry ready.

## Recommended Posts:

- Difference between Relational Algebra and Relational Calculus
- SELECT Operation in Relational Algebra
- Cartesian Product Operation in Relational Algebra
- RENAME (ρ) Operation in Relational Algebra
- Difference between Tuple Relational Calculus (TRC) and Domain Relational Calculus (DRC)
- Introduction of Relational Algebra in DBMS
- Extended Operators in Relational Algebra
- Basic Operators in Relational Algebra
- How to solve Relational Algebra problems for GATE
- Query Optimization in Relational Algebra
- Set Theory Operations in Relational Algebra
- Types of Keys in Relational Model (Candidate, Super, Primary, Alternate and Foreign)
- Relational Model in DBMS
- Mapping from ER Model to Relational Model
- Introduction of Relational Model and Codd Rules in DBMS
- Anomalies in Relational Model
- Tuple Relational Calculus (TRC) in DBMS
- Domain Relational Calculus in DBMS
- Properties of Relational Decomposition
- Violation of constraints in relational database

If you like GeeksforGeeks and would like to contribute, you can also write an article using contribute.geeksforgeeks.org or mail your article to contribute@geeksforgeeks.org. See your article appearing on the GeeksforGeeks main page and help other Geeks.

Please Improve this article if you find anything incorrect by clicking on the "Improve Article" button below.