KEMBAR78
DBMS | PDF | Information Retrieval | Databases
0% found this document useful (0 votes)
352 views25 pages

DBMS

The document describes a database with tables for colleges, staff, classes, subjects, and enrollment/admissions data. It includes: 1. SQL statements to create the tables with columns and constraints 2. Sample INSERT statements to add initial data to the tables 3. Multiple JOIN queries to retrieve relevant data, such as lists of teachers by subject, staff details, enrolled students details, and fees collected. The document provides the SQL needed to setup the database tables, populate them with sample data, and write queries to solve tasks like listing teachers by subject taught, staff details, student enrollment details, and fees collection reports.

Uploaded by

Mohummad Rashid
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
352 views25 pages

DBMS

The document describes a database with tables for colleges, staff, classes, subjects, and enrollment/admissions data. It includes: 1. SQL statements to create the tables with columns and constraints 2. Sample INSERT statements to add initial data to the tables 3. Multiple JOIN queries to retrieve relevant data, such as lists of teachers by subject, staff details, enrolled students details, and fees collected. The document provides the SQL needed to setup the database tables, populate them with sample data, and write queries to solve tasks like listing teachers by subject taught, staff details, student enrollment details, and fees collection reports.

Uploaded by

Mohummad Rashid
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
You are on page 1/ 25

PROGRAM 1

Q. Using the following database,


Colleges (cname, city, address, phone, afdate)
Staffs (sid, sname, saddress, contacts)
StaffJoins (sid, cname, dept, doj, post, salary)
Teacings (sid, class, paperid, fsession, tsession)
Subjects (paperid, subject, paperno, papername)
Write sql statements for the following:-
a. Create the above table with the given specifications and constraints
create table colleges
(
cname varchar(10),
city varchar(10),
address varchar(10),
phone int,
afdate date
);
create table staffs
(
sid int,
sname varchar(10),
saddress varchar(10),
contacts int
);
create table staffjoins
(
sid int,
cname varchar(10),
dept varchar(5),
doj date,
post varchar(5),
salary int
);
create table teachings
(
sid int,
class int,
paperid int,
fsession varchar(7),
tsession varchar(7)
);
create table subjects
(
paperid int,
subject varchar(8),
paperno int,
papername varchar(10)
);
Output:
b. Insert about 5 rows as are appropriate to solve following queries.
INSERT ALL
INTO colleges VALUES ('Pallotti','Raipur','Kapa',1234567890,'27-jun-90')
INTO colleges VALUES ('Mats','Raipur','Bus Stand', 3421567432,'05-apr-01')
INTO colleges VALUES ('ITM','Bilaspur','Ring Road',9876098123,'10-nov-98')
INTO colleges VALUES ('Amity','Durg','Bhilai',9876754321,'16-feb-99')
INTO colleges VALUES ('Maic','Raipur','Moa',1265347865,'23-jan-98')
SELECT * FROM dual;

INSERT ALL
INTO staffs VALUES(1101,'Jon','Pandri',9302631457)
INTO staffs VALUES(1200,'Dan','Ring Road',9874521547)
INTO staffs VALUES(1602,'Mary','Moa',8014527854)
INTO staffs VALUES(5572,'John','Srinagar',5567182321)
INTO staffs VALUES(1667,'Karen','Bhilai',9856327410)
SELECT * FROM dual;

INSERT ALL
INTO staffjoins VALUES(1101,'Pallotti','Comm','27-jan-07','Prof',20000)
INTO staffjoins VALUES(1200,'ITM','Sci','24-oct-02','Profr',25000)
INTO staffjoins VALUES(1602,'Maic','Comp','12-apr-11','Prof',22000)
INTO staffjoins VALUES(5572,'Mats','Edu','30-jul-05','Prof',15000)
INTO staffjoins VALUES(1667,'Amity','Comm','21-jun-07','HOD',30000)
SELECT * FROM dual;

INSERT ALL
INTO teachings VALUES(1101,'1',00102,'Apr-Mar','Aug-Feb')
INTO teachings VALUES(1200,'2',01212,'Apr-Mar','Aug-Feb')
INTO teachings VALUES(1602,'1',04021,'Apr-Mar','Aug-Jan')
INTO teachings VALUES(5575,'3',05214,'Apr-Mar','Aug-Mar')
INTO teachings VALUES(1667,'2',00102,'Apr-Mar','Aug-Mar')
SELECT * FROM dual;

INSERT ALL
INTO subjects VALUES(00102,'Bcom',01,'Economics')
INTO subjects VALUES(01212,'Bsc',03,'Chemistry')
INTO subjects VALUES(04021,'BCA',01,'DBMS')
INTO subjects VALUES(05214,'BEd',02,'English')
INTO subjects VALUES(00102,'BCOm',01,'Accounts')
SELECT * FROM dual;

Output:
c. List the names of teachers teaching computer subjects.
SELECT staffs.sname
FROM staffs
INNER JOIN teachings
ON staffs.sid = teachings.sid
INNER JOIN subjects
ON teachings.paperid = subjects.paperid
WHERE subjects.subject='BCA';

d. List the names and cities of all the staff working in your college.
SELECT staffs.sname, staffs.saddress
FROM staffs
INNER JOIN staffjoins
ON staffs.sid = staffjoins.sid
INNER JOIN colleges
ON staffjoins.cname = colleges.cname
WHERE colleges.cname='Pallotti';
e. List the names and cities of all staff working in your college who earn more than
15000.
SELECT staffs.sname, staffs.saddress
FROM staffs
INNER JOIN staffjoins
ON staffs.sid = staffjoins.sid
INNER JOIN colleges
ON staffjoins.cname = colleges.cname
WHERE colleges.cname='Pallotti'
AND staffjoins.salary>15000;

Output:

f. Find the staffs whose names starts with M or R and ends with A and/or 7 characters
long.
SELECT sname
FROM staffs
WHERE (sname LIKE 'M%' OR sname LIKE 'R%')
AND sname LIKE '%A' OR sname LIKE '_______';

Output:
g. Find the staffs whose date of joining is 2005.
SELECT sname
FROM staffs INNER JOIN staffjoins
ON staffs.sid=staffjoins.sid
WHERE (EXTRACT(YEAR from doj)=2005);

Output:

h. Modify the database so that staff S1 now works in C2 college.


UPDATE staffjoins
SET cname ='Pallotti'
WHERE sid=1200;

Output:

i. List the names of subjects which T1 teaches in this session or all Session.
SELECT subject
FROM subjects FULL OUTER JOIN teachings
ON subjects.paperid=teachings.paperid
FULL OUTER JOIN staffs
ON teachings.sid=staffs.sid
WHERE staffs.sname='Jon' AND teachings.tsession='Aug-Feb';
Output:

j. List names of employees in ascending order according to salary who are working in
your college or all colleges.
1. Create a view having fields sname, cname, dept, DOJ and post.
CREATE VIEW details AS
SELECT staffs.sname,staffjoins.cname,staffjoins.dept,staffjoins.doj,staffjoins.post
FROM staffs INNER JOIN staffjoins
ON staffs.sid=staffjoins.sid;
Output:

2. Create a view consisting of cname and salary of all the staff.


CREATE VIEW sal AS
SELECT staffjoins.cname,staffjoins.salary
FROM staffjoins;

Output:

3. List the staff names according to salary using above views.


SELECT sname
FROM details LEFT OUTER JOIN sal
ON details.cname = sal.cname
ORDER BY sal.salary ASC;
Output:
PROGRAM 2
Q2. Create the following database,
Enrollment (enrollno, name, gender, dob, address, phone)
Admission (admno, enrollno, course, yearsem, adate, cname)
Colleges (cname, city, address, phone, afdate)
FeeStructure (course, yearsem, fee)
Payment (billno, admno, pdate, purpose)
Write the sql queries for the following:
a. Create the above tables with the given specifications and criteria.
CREATE TABLE enrollment
(
enrollno int,
ename varchar(20),
gender char,
dob date,
address varchar(20),
phone int
);
CREATE TABLE admission
(
admno int,
enrollno int,
course varchar(5),
yearsem int,
adate date,
cname varchar(20)
);
CREATE TABLE college
(
cname varchar(20),
city varchar(20),
address varchar(20),
phone int,
afdate date
);
CREATE TABLE feestructure
(
course varchar(5),
yearsem int,
fee int
);
CREATE TABLE payment
(
billno int,
admno int,
amount int,
pdate date,
purpose varchar(20)
);
Output:
b. Insert about 5 rows as are appropriate to solve the following queries.
INSERT ALL
INTO enrollment VALUES(121,'Joe','M','27-jan-01','Devendra Nagar',1236547890)
INTO enrollment VALUES(122,'Dan','M','17-mar-00','Kapa',2587413690)
INTO enrollment VALUES(123,'Lucy','F','13-jun-99','Moa',1254789630)
INTO enrollment VALUES(124,'Mary','F','20-oct-01','Pandri',4569871230)
INTO enrollment VALUES(125,'Kara','F','03-dec-01','Fafadih',7845129637)
SELECT * FROM DUAL;

INSERT ALL
INTO admission VALUES(101,121,'BCA',1,'12-jun-19','ITM')
INTO admission VALUES(102,122,'BCom',1,'02-jun-19','Pallotti')
INTO admission VALUES(103,123,'BCom',2,'15-jun-19','Mats')
INTO admission VALUES(104,124,'BEd',1,'10-jun-19','Pallotti')
INTO admission VALUES(105,125,'BCA',2,'06-jun-19','Amity')
SELECT * FROM DUAL;

INSERT ALL
INTO college VALUES('Pallotti','Raipur','Kapa',1245879635,'28-oct-90')
INTO college VALUES('ITM','Raipur','VIP Road',7854123691,'15-apr-01')
INTO college VALUES('Mats','Raipur','Bus Stand',7898456512,'02-jan-90')
INTO college VALUES('Amity','Raipur','Vidhan Sabha',8456957912,'12-apr-01')
INTO college VALUES('Maic','Raipur','Gayatri Nagar',565896321,'20-jun-95')
SELECT * FROM DUAL;

INSERT ALL
INTO feestructure VALUES('BCA',1,26000)
INTO feestructure VALUES('BCA',2,27000)
INTO feestructure VALUES('BCom',1,20000)
INTO feestructure VALUES('BCom',2,21000)
INTO feestructure VALUES('BEd',1,20000)
SELECT * FROM DUAL;

INSERT ALL
INTO payment VALUES(1041,101,26000,'27-jun-19','Fee Payment')
INTO payment VALUES(1042,102,20000,'20-jun-19','Fee Payment')
INTO payment VALUES(1043,103,21000,'19-jun-19','Fee Payment')
INTO payment VALUES(1044,104,25000,'29-jun-19','Fee Payment')
INTO payment VALUES(1045,105,19000,'25-jun-19','Fee Payment')
SELECT * FROM DUAL;

Output:
c. Get full detail of all the students who took admission this year class wise
SELECT enrollment.enrollno, enrollment.ename, enrollment.gender, enrollment.dob,
enrollment.address, enrollment.phone, admission.course, admission.yearsem
FROM enrollment INNER JOIN admission
ON enrollment.enrollno=admission.enrollno
WHERE (EXTRACT(YEAR FROM adate)=2019)
ORDER BY yearsem ASC;

Output:

d. Get the details of the students who took admission in Bhilai colleges.
SELECT enrollment.enrollno, enrollment.ename, enrollment.gender, enrollment.dob,
enrollment.address, enrollment.phone, admission.course, admission.yearsem
FROM enrollment INNER JOIN admission
ON enrollment.enrollno=admission.enrollno
INNER JOIN college
ON admission.cname=college.cname
WHERE college.city ='Bhilai';
Output:

e. Calculate the total amount of fees collected in this session by.


1. Your College
SELECT SUM(amount)
FROM payment INNER JOIN admission
ON payment.admno = admission.admno
WHERE admission.cname = 'Pallotti';

Output:

2. All Colleges.
SELECT SUM(amount)
FROM payment INNER JOIN admission
ON payment.admno = admission.admno;

Output:

f. List the students who have not paid full fee.


1. In all Coleges
SELECT enrollment.ename, feestructure.fee-payment.amount AS remaining,
admission.cname
FROM enrollment INNER JOIN admission
ON enrollment.enrollno=admission.enrollno
INNER JOIN payment
ON admission.admno=payment.admno
INNER JOIN feestructure
ON admission.course=feestructure.course AND
admission.yearsem=feestructure.yearsem
WHERE (feestructure.fee-payment.amount !=0);

Output:

2. In your College.
SELECT enrollment.ename, feestructure.fee-payment.amount AS remaining,
admission.cname
FROM enrollment INNER JOIN admission
ON enrollment.enrollno=admission.enrollno
INNER JOIN payment
ON admission.admno=payment.admno
INNER JOIN feestructure
ON admission.course=feestructure.course AND
admission.yearsem=feestructure.yearsem
WHERE (feestructure.fee-payment.amount !=0) AND
(admission.cname='Pallotti');
Output:
PROGRAM 3
Q3. Create the following tables:
Subjects (paperid, subject, paper, papername)
Test (paperid, date, time, max, min)
Score (rollno, paperid, marks attendence)
Students (admno, rollno, class, yearsem)
Write sql statements for the following queries
a. Create the above table with the given specifications and constraints.
CREATE TABLE subject
(
paperid int,
subject varchar(20),
paper int,
papername varchar(20)
);
CREATE TABLE test
(
paperid int,
tdate date,
ttime date,
tmax int,
tmin int
);
CREATE TABLE score
(
rollno int,
paperid int,
marks int,
attendence int
);
CREATE TABLE students
(
admno int,
rollno int,
class varchar(5),
yearsem int
);

Output:
b. Insert about 5 rows as are appropriate to solve the following queries.
INSERT ALL
INTO subject VALUES(101,'C++',01,'Programming in c++')
INTO subject VALUES(102,'DBMS',02,'DBMS')
INTO subject VALUES(103,'OS',03,'OS with Linux')
INTO subject VALUES(104,'Networks',04,'Computer Networks')
INTO subject VALUES(105,'Maths',05,'Calculus & Diff Equ')
SELECT * FROM DUAL;

INSERT ALL
INTO test VALUES(101,'02-jan-19',to_date('09:30:00','HH24:MI:SS'),50,12)
INTO test VALUES(102,'03-jan-19',to_date('09:30:00','HH24:MI:SS'),50,12)
INTO test VALUES(103,'04-jan-19',to_date('09:30:00','HH24:MI:SS'),50,12)
INTO test VALUES(104,'05-jan-19',to_date('09:30:00','HH24:MI:SS'),50,12)
INTO test VALUES(105,'06-jan-19',to_date('09:30:00','HH24:MI:SS'),50,12)
SELECT * FROM DUAL;

INSERT ALL
INTO score VALUES(1,101,46,'P')
INTO score VALUES(1,102,38,'P')
INTO score VALUES(1,103,42,'P')
INTO score VALUES(1,104,50,'P')
INTO score VALUES(1,105,45,'P')
INTO score VALUES(2,101,50,'P')
INTO score VALUES(2,102,48,'P')
INTO score VALUES(2,103,41,'P')
INTO score VALUES(2,104,50,'P')
INTO score VALUES(2,105,45,'P')
INTO score VALUES(3,101,41,'P')
INTO score VALUES(3,102,36,'P')
INTO score VALUES(3,103,00,'A')
INTO score VALUES(3,104,42,'P')
INTO score VALUES(3,105,39,'P')
INTO score VALUES(4,101,45,'P')
INTO score VALUES(4,102,00,'A')
INTO score VALUES(4,103,49,'P')
INTO score VALUES(4,104,40,'P')
INTO score VALUES(4,105,42,'P')
SELECT * FROM DUAL;

INSERT ALL
INTO students VALUES(121,1,'BCA',2)
INTO students VALUES(122,2,'BCA',2)
INTO students VALUES(123,3,'BCA',2)
INTO students VALUES(124,4,'BCA',2)
INTO students VALUES(125,5,'BCA',2)
SELECT * FROM DUAL;

Output:
c. List the students who were present in a paper of a subject.
SELECT score.rollno,score.attendence
FROM score FULL OUTER JOIN subject
ON score.paperid=subject.paperid
WHERE (subject.subjectn='DBMS') AND (score.attendence='P');

Output:

d. List all the roll numbers who have passed in first division.
SELECT rollno, SUM(marks) AS total_marks
FROM score
GROUP BY rollno
HAVING SUM(marks)>188;

Output:

You might also like