Thursday 29 February 2024
Tarang Sanchar Web Portal Kya hai
Tuesday 20 February 2024
Projection and Selection Practice Questions in relational algebra
Projection and Selection Practice Questions:
Student
S_ID |
NAME |
Branch |
1 |
A |
CS |
2 |
B |
IT |
3 |
C |
CS |
4 |
D |
CS |
5 |
E |
EE |
6 |
F |
EC |
7 |
G |
EE |
- Find the names of all students from CS branch.
Π name (σ Branch = ‘CS’ (Student))
Account (account_no, branch_name, balance)
- Find those account numbers where balance is less than 1000.
Π account_no (σ balance<1000 (Account))
Loan(loan_no, branch_name, amount)
- Find those loan numbers which are from Delhi branch with amount greater than 1000.
Π loan_no (σ branch_name=’Delhi’ ^ amount>1000 (Loan))
Branch (Branch_name, Branch_city, assets)
- Find branch_name and branch_city with assets more than 100000.
Π branch_name , branch_city (σ assets>100000 (Branch))
Projection Operator in Relational Algebra
Projection Operator-
- Projection Operator (π) is a unary operator in relational algebra that performs a projection operation.
- It displays the columns of a relation or table based on the specified attributes.
- It is a fundamental / Basic operator
- It is a unary operator
Syntax-
π<attribute list>(R) |
Example-
Consider the following Student relation-
ID | Name | Subject | Age |
100 | Ashish | Maths | 19 |
200 | Rahul | Science | 20 |
300 | Naina | Physics | 20 |
400 | Sameer | Chemistry | 21 |
Student
Result for Query πName, Age(Student)-
Name | Age |
Ashish | 19 |
Rahul | 20 |
Naina | 20 |
Sameer | 21 |
Result for Query πID , Name(Student)-
ID | Name |
100 | Ashish |
200 | Rahul |
300 | Naina |
400 | Sameer |
Important Points-
Point-01:
- The degree of output relation (number of columns present) is equal to the number of attributes mentioned in the attribute list.
Point-02:
- Projection operator automatically removes all the duplicates while projecting the output relation.
- So, cardinality of the original relation and output relation may or may not be same.
- If there are no duplicates in the original relation, then the cardinality will remain same otherwise it will surely reduce.
Point-03:
- If attribute list is a super key on relation R, then we will always get the same number of tuples in the output relation.
- This is because then there will be no duplicates to filter.
Point-04:
- Projection operator does not obey commutative property i.e.
π <list2> (π <list1> (R)) ≠ π <list1> (π <list2> (R))
Point-05:
- Selection Operator performs horizontal partitioning of the relation.
- Projection operator performs vertical partitioning of the relation.
Point-06:
- There is only one difference between projection operator of relational algebra and SELECT operation of SQL.
- Projection operator does not allow duplicates while SELECT operation allows duplicates.
- To avoid duplicates in SQL, we use “distinct” keyword and write SELECT distinct.
- Thus, projection operator of relational algebra is equivalent to SELECT operation of SQL.
Selection Operator in Relational Algebra
Selection
Operator-
·
Selection Operator (σ) is a unary operator in relational
algebra that performs a selection operation.
·
It selects those rows or tuples from the relation that
satisfies the selection condition.
·
It is a fundamentals / Basic operator
·
It is a Unary Operator
σ<selection_condition>(R)
·
Select tuples from a relation “Books” where subject is
“database”
σsubject = “database” (Books)
·
Select tuples from a relation “Books” where subject is
“database” and price is “450”
σsubject = “database” ∧ price = “450” (Books)
·
Select tuples
from a relation “Books” where subject is “database” and
price is “450” or have a publication year after 2010
σsubject = “database” ∧ price =
“450” ∨
year >”2010″ (Books)
Important
Points-
Point-01:
·
We may use logical operators like ∧ , ∨ , ! and relational operators
like = , ≠ , > , < , <= , >= with the selection
condition.
Point-02:
·
Selection operator only selects the required tuples
according to the selection condition.
·
It does not display the selected tuples.
·
To display the selected tuples, projection operator is
used.
Point-03:
·
Selection operator always selects the entire tuple. It
can not select a section or part of a tuple.
Point-04:
·
Selection operator is commutative in nature i.e.
σ A ∧ B (R)
= σ B ∧ A (R)
OR
σ B (σ A(R))
= σ A (σ B(R))
Point-05:
·
Degree of the relation from a selection operation is same
as degree of the input relation.
Point-06:
· The number of rows returned by a selection operation is obviously less than or equal to the number of rows in the original table.
·
Minimum Cardinality = 0
·
Maximum Cardinality = |R|
Friday 16 February 2024
Class 11 CS Practical - 52
52 - Write a program in Python to find the mean of numeric values stored in the given tuple.
T=eval(input("Enter a numeric tuple: "))
print("Tuple is: \n", T)
mean=sum(T)/len(T)
print("Mean of the numeric values of the tuple = ",mean)
Output:
Enter a numeric tuple: (2, 8, 9, 6, 5)
Tuple is:
(2, 8, 9, 6, 5)
Mean of the numeric values of the tuple = 6.0
Thursday 15 February 2024
Class 11 CS Practical - 51
51 - Write a program in Python to count the frequency of all elements of a tuple
T= (10, 20, 30, 20, 40, 30, 20, 50)
print("Tuple is: ",T)
Uni= ()
for i in T:
if i not in Uni:
Uni = Uni + (i,)
for i in Uni:
print(i,":",T.count(i))
Output:
Tuple is: (10, 20, 30, 20, 40, 30, 20, 50)
10 : 1
20 : 3
30 : 2
40 : 1
50 : 1
Class 11 CS Practical - 50
50 - Write a program in Python to count the frequency of all elements of a list.
L= [10, 20, 30, 20, 40, 30, 20, 50]
print("List is: ",L)
Uni= []
Freq= []
for i in L:
if i in Uni:
index=Uni.index(i)
Freq[index]+= 1
else:
Uni.append(i)
Freq.append(1)
for i in range(len(Uni)):
print(Uni[i],":",Freq[i])
Output:
List is: [10, 20, 30, 20, 40, 30, 20, 50]
10 : 1
20 : 3
30 : 2
40 : 1
50 : 1
Class 11 CS Practical - 49
49 - WAP in the Python to create a list and find the mean of all numeric values stored in the list.
L=eval(input("Enter a list: "))
n=len(L)
N=[]
for i in L:
if isinstance(i,int) or isinstance(i,float):
N.append(i)
print("Mean of numeric values stored in the list:")
print(sum(N)/len(N))
Output:
Enter a list: [5,'A',9,6.5,'Python',3.5]
Mean of numeric values stored in the list:
6.0
Class 11 CS Practical - 48
48 - WAP in Python to create a dictionary with name of employee, their salary and access them.
Emp={}
c='y'
while c in 'yY':
name=input("Enter the name of employee: ")
salary=float(input("Enter the salary of employee: "))
Emp[name]=salary
c=input("Do you want to add more emp(y/n): ")
print("Details of Employee:")
print(Emp)
Output:
Enter the name of employee: Ram
Enter the salary of employee: 38545
Do you want to add more emp(y/n): y
Enter the name of employee: Raj
Enter the salary of employee: 45854
Do you want to add more emp(y/n): y
Enter the name of employee: Aman
Enter the salary of employee: 47825
Do you want to add more emp(y/n): n
Details of Employee:
{'Ram': 38545.0, 'Raj': 45854.0, 'Aman': 47825.0}
Class 11 CS Practical - 47
47 - WAP in Python to input a string and display the frequency of each character using dictionary
S=input("Enter a string: ")
F={}
for i in S:
if i in F:
F[i]+=1
else:
F[i]=1
print("Frequency of characters in the given string: ")
for i, j in F.items():
print(i,":",j)
Output:
Enter a string: S P SHARMA
Frequency of characters in the given string:
S : 2
: 2
P : 1
H : 1
A : 2
R : 1
M : 1
-
'''Practical No: 9: WAP in Python to create a binary file with roll_no, name and marks of the students and update the marks of...
-
List of Python with CS practical for class 12 Part – 1 Python with CS 1) WAP in Python to find the factorial of a number using fun...
-
''' Practical No: 7: WAP in Python to create a binary file with name and roll number of the students. Search for a given roll ...