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 DSA concepts with the **DSA Self Paced Course** at a student-friendly price and become industry ready.

## Recommended Posts:

- RENAME (ρ) Operation in Relational Algebra
- SELECT Operation in Relational Algebra
- Cartesian Product Operation in Relational Algebra
- Difference between Relational Algebra and Relational Calculus
- Introduction of Relational Algebra in DBMS
- Extended Operators in Relational Algebra
- Query Optimization in Relational Algebra
- Basic Operators in Relational Algebra
- Set Theory Operations in Relational Algebra
- How to solve Relational Algebra problems for GATE
- Difference between Tuple Relational Calculus (TRC) and Domain Relational Calculus (DRC)
- Relational Query Evaluation | Set 2
- Relational Query Evaluation | Set 1
- Relational Model in DBMS
- Anomalies in Relational Model
- Properties of Relational Decomposition
- Difference between Relational database and NoSQL
- Violation of constraints in relational database
- Tuple Relational Calculus (TRC) in DBMS
- Difference between CouchDB and 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.