0% found this document useful (0 votes)
24 views45 pages

DBMS Lab Mannual

lab Manual

Uploaded by

mathpati8055
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)
24 views45 pages

DBMS Lab Mannual

lab Manual

Uploaded by

mathpati8055
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/ 45

DEPARTMENT OF ARTIFICIAL INTELLIGENCE & DATA SCIENCE

FACULTY OF ENGINEERING AND TECHNOLOGY(CO-ED)

SHARNBASVA UNIVERSITY KALABURAGI

Introduction To DataBase
Management System Lab Manual
For 4th Semester
Course Code: 22ADL47

By
Prof. Revati Sugoor
List of Experiments
LIBRARY DATABASE
1. Demonstrating creation of tables, applying the view concepts on the tables.

Consider the following schema for a Library Database:

 BOOK(Book_id, Title, Publisher_Name, Pub_Year)


 BOOK_AUTHORS(Book_id, Author_Name)
 PUBLISHER(Name, Address, Phone)
 BOOK_COPIES(Book_id, Programme_id, No-of_Copies)
 BOOK_LENDING(Book_id, Programme_id, Card_No, Date_Out, Due_Date)
 LIBRARY_PROGRAMME(Programme_id,
Programme_Name, Address) Write SQL queries to:

1. Retrieve details of all books in the library – id, title, name of publisher, authors, number of
copies in each Programme, etc.
2. Get the particulars of borrowers who have borrowed more than 3 books, but from Jan 2022 to
Jun 2022.
3. Delete a book in BOOK table. Update the contents of other tables to reflect this data
manipulation operation.
4. Partition the BOOK table based on year of publication. Demonstrate its working with a
simple query. Create a view of all books and its number of copies that are currently
available in the library.
ORDER DATABASE:
2. Discuss the various concepts on constraints and update operations.

Consider the following schema for Order Database:

SALESMAN(Salesman_id, Name, City, Commission)


 CUSTOMER (Customer_id, Cust_Name, City, Grade, Salesman_id)
ORDERS (Ord_No, Purchase_Amt, Ord_Date, Customer_id, Salesman_id)

Write SQL queries to:


1. Count the customers with grades above Bangalore’s average.
2. Find the name and numbers of all salesman who had more than one customer.
3. List all the salesman and indicate those who have and do not have customers in their cities
(Use UNION operation.)
4. Create a view that finds the salesman who has the customer with the highest order of a
day. Demonstrate the DELETE operation by removing salesman with id 1000. All his
orders must also be deleted.
MOVIE DATABASE

3. Demonstrate the concepts of JOIN operations.Consider the schema for Movie Database:
 ACTOR (Act_id, Act_Name, Act_Gender)
 DIRECTOR (Dir_id, Dir_Name, Dir_Phone)
 MOVIES (Mov_id, Mov_Title, Mov_Year, Mov_Lang, Dir_id)
 MOVIE_CAST (Act_id, Mov_id, Role)
 RATING (Mov_id, Rev_Stars)

Write SQL queries to:


1. List the titles of all movies directed by ‘Hitchcock’.
2. Find the movie names where one or more actors acted in two or more movies.
3. List all actors who acted in a movie before 2000 and in a movie after 2015 (use JOIN
operation).
4. Find the title of movies and number of stars for each movie that has at least one rating
and find the highest number of stars that movie received. Sort the result by movie
title.
5. Update rating of all movies directed by ‘Steven Spielberg’ to 5.

COLLEGE DATABASE

4. Introduce concepts of PLSQL and usage on the table.

Consider the schema for College Database:

 STUDENT (USN, SName, Address, Phone, Gender)


 SEMSEC (SSID, Sem, Sec)
 CLASS (USN, SSID)
 COURSE (Subcode, Title, Sem, Credits)
 IAMARKS (USN, Subcode, SSID, Test1, Test2, Test3, FinalIA)

Write SQL queries to:


1. List all the student details studying in fourth semester ‘C’ section.
2. Compute the total number of male and female students in each semester and in each section.
3. Create a view of Test1 marks of student USN ‘1BI15CS101’ in all Courses.
Calculate the Final IA (average of best two test marks) and update the corresponding table for all
students.

5. Categorize students based on the


following criterion: If FinalIA = 17 to 20
then CAT = ‘Outstanding’
If FinalIA = 12 to 16 then CAT
= ‘Average’ If FinalIA< 12 then
CAT = ‘Weak’
Give these details only for 8th semester A, B, and C section students.
COMPANY DATABASE

5. Demonstrate the core concepts on table like nested and correlated nested queries and
also EXISTS and NOT-EXISTS keywords.

Consider the schema for Company Database:

 EMPLOYEE(SSN, Name, Address, Sex, Salary, SuperSSN, DNo)


 DEPARTMENT(DNo, DName, MgrSSN, MgrStartDate)
 DLOCATION(DNo,DLoc)
 PROJECT(PNo, PName, PLocation, DNo)
 WORKS_ON(SSN, PNo, Hours)

Write SQL queries to:


1. Make a list of all project numbers for projects that involve an employee whose last name is
‘Scott’, either as a worker or as a manager of the department that controls the project.
2. Show the resulting salaries if every employee working on the ‘IoT’ project is given a 10
percent raise.
3. Find the sum of the salaries of all employees of the ‘Accounts’ department, as well as the
maximum salary, the minimum salary, and the average salary in this department.
4. Retrieve the name of each employee who works on all the projects controlled by department
number 5 (use NOT EXISTS operator).
5. For each department that has more than five employees, retrieve the department number and
the number of
its employees who are making more than Rs. 6,00,000.
INSTRUCTIONS TO STUDENTS
 Before entering the lab the student should carry the following
things (MANDATORY)
1. Identity card issued by the college.
2. Class notes
3. Lab observation book
4. Lab Manual
5. Lab Record
 Copy all the programs to observation which are taught in class before attending
the laboratory session.
 All Students should wear uniforms while entering the laboratory
 Workspace must be kept clean and tidy after experiment is completed.
 All bags must be placed at the indicated place.
 Refer concerned staff if you need any help in using the laboratory.
 Shut down the computer properly after done with your experiment.
 When you are done with your project, system must be returned to proper locations.
 Lab records need to be submitted on or before the date of submission.
 Do not use floppy disks, pen drives on computers without permission of lab- in
charge.
 Do not enter restricted areas without permission.
 Do not talk aloud or crack jokes in laboratory.
 Do not eat food, drink beverages or chew gum in the laboratory.
 Do not touch any part of the computer with wet hands.
 Do not hit the keys on the computer too hard.
 Do not open any irrelevant internet sites on computer/laptop.
 Do not install or download any software or modify or delete any system files on
any computers in the laboratory.
 Do not wander in the lab room and distract other students.
 You are not allowed to work in the laboratory alone or without presence of the faculty
or instructor.
 Please report any unsafe behaviour or condition to the instructor or staff.
1. Demonstrating creation of tables, applying the view concepts on the tables.

Consider the following schema for a Library Database:

 BOOK(Book_id, Title, Publisher_Name, Pub_Year)


 BOOK_AUTHORS(Book_id, Author_Name)
 PUBLISHER(Name, Address, Phone)
 BOOK_COPIES(Book_id, Programme_id, No-of_Copies)
 BOOK_LENDING(Book_id, Programme_id, Card_No, Date_Out, Due_Date)
 LIBRARY_PROGRAMME(Programme_id, Programme_Name,
Address)
 Write SQL queries to:

1 Retrieve details of all books in the library – id, title, name of publisher, authors, number of copies in
each Programme, etc.
2 Get the particulars of borrowers who have borrowed more than 3 books, but from Jan 2022 to Jun 2022.
3 Delete a book in BOOK table. Update the contents of other tables to reflect this data
manipulation operation.
4 Partition the BOOK table based on year of publication. Demonstrate its working with a simple
query. Create a view of all books and its number of copies that are currently available in the library.

SCHEMA DIAGRAM
Table Creation

CREATE TABLE BOOK (


BOOK_ID INT (10) PRIMARY
KEY, TITLE VARCHAR (20),
PUB_YEAR VARCHAR (20),
PUBLISHER_NAME VARCHAR (20),
FOREIGN KEY (PUBLISHER_NAME) REFERENCES PUBLISHER (NAME) ON DELETE
CASCADE);

CREATE TABLE BOOK_AUTHORS (


AUTHOR_NAME VARCHAR (20),
BOOK_ID INT (10),
PRIMARY KEY (BOOK_ID, AUTHOR_NAME),
FOREIGN KEY (BOOK_ID) REFERENCES BOOK (BOOK_ID) ON DELETE CASCADE);

CREATE TABLE PUBLISHER (


NAME VARCHAR (20) PRIMARY KEY,
PHONE BIGINT (20),
ADDRESS VARCHAR (100));

CREATE TABLE BOOK_COPIES (


NO_OF_COPIES INT (5),
BOOK_ID INT (10),
PROGRAMME_ID INT (10),
PRIMARY KEY (BOOK_ID,PROGRAMME_ID),
FOREIGN KEY (BOOK_ID) REFERENCES BOOK (BOOK_ID) ON DELETE CASCADE,
FOREIGN KEY (PROGRAMME_ID) REFERENCES LIBRARY_PROGRAMME
(PROGRAMME_ID) ON DELETE CASCADE);

CREATE TABLE BOOK_LENDING (


DATE_OUT DATE,
DUE_DATE DATE,
BOOK_ID INT (10),
PROGRAMME_ID INT (10),
CARD_NO INT (10),
PRIMARY KEY (BOOK_ID,PROGRAMME_ID, CARD_NO),
FOREIGN KEY (BOOK_ID) REFERENCES BOOK (BOOK_ID) ON DELETE CASCADE,
FOREIGN KEY (PROGRAMME_ID) REFERENCES
LIBRARY_PROGRAMME(PROGRAMME_ID) ON DELETE CASCADE,
FOREIGN KEY (CARD_NO) REFERENCES CARD (CARD_NO) ON DELETE CASCADE);

CREATE TABLE CARD (


CARD_NO INT (10) PRIMARY KEY);

CREATE TABLE LIBRARY_PROGRAMME (


PROGRAMME_ID INT (10) PRIMARY KEY,
PROGRAMME_NAME VARCHAR (50),
ADDRESS VARCHAR (100));

Insertion of Values to Tables

INSERT INTO BOOK VALUES (1,'DBMS','JAN-2017', 'MCGRAW-HILL');


INSERT INTO BOOK VALUES (2,'ADBMS','JUN-2016','MCGRAW-HILL');
INSERT INTO BOOK VALUES (3, 'CD','SEP-2016','PEARSON');
INSERT INTO BOOK VALUES (4,' ALGORITHMS ','SEP-2015',' MIT');
INSERT INTO BOOK VALUES (5,'OS','MAY-2016','PEARSON');

INSERT INTO BOOK_AUTHORS VALUES ('NAVATHE', 1);


INSERT INTO BOOK_AUTHORS VALUES ('NAVATHE', 2);
INSERT INTO BOOK_AUTHORS VALUES ('ULLMAN',3);
INSERT INTO BOOK_AUTHORS VALUES ('CHARLES', 4);
INSERT INTO BOOK_AUTHORS VALUES('GALVIN', 5);

INSERT INTO PUBLISHER VALUES ('MCGRAW-HILL', 9989076587,'BANGALORE');


INSERT INTO PUBLISHER VALUES ('PEARSON', 9889076565,'NEWDELHI');
INSERT INTO PUBLISHER VALUES ('PRENTICE HALL', 7455679345,'HYEDRABAD');
INSERT INTO PUBLISHER VALUES ('WILEY', 8970862340,'CHENNAI');
INSERT INTO PUBLISHER VALUES ('MIT',7756120238,'BANGALORE');

INSERT INTO BOOK_COPIES VALUES (10, 1, 10);


INSERT INTO BOOK_COPIES VALUES (5, 1, 11);
INSERT INTO BOOK_COPIES VALUES (2, 2, 12);
INSERT INTO BOOK_COPIES VALUES (5, 2, 13);
INSERT INTO BOOK_COPIES VALUES (7, 3, 14);
INSERT INTO BOOK_COPIES VALUES (1, 5, 10);
INSERT INTO BOOK_COPIES VALUES (3, 4, 11);

INSERT INTO BOOK_LENDING VALUES ('2017-01-01','2017-06-01', 1, 10, 101);


INSERT INTO BOOK_LENDING VALUES ('2017-01-11 ','2017-03-11', 3, 14, 101);
INSERT INTO BOOK_LENDING VALUES ('2017-02-21','2017-04-21', 2, 13, 101);
INSERT INTO BOOK_LENDING VALUES ('2017-03-15 ','2017-07-15', 4, 11, 101);
INSERT INTO BOOK_LENDING VALUES ('2017-04-12','2017-05-12', 1, 11, 104);

INSERT INTO CARD VALUES (100);


INSERT INTO CARD VALUES (101);
INSERT INTO CARD VALUES (102);
INSERT INTO CARD VALUES (103);
INSERT INTO CARD VALUES (104);

INSERT INTO LIBRARY_PROGRAMME VALUES (10,'VIJAY NAGAR','MYSURU');


INSERT INTO LIBRARY_PROGRAMME VALUES (11,'VIDYANAGAR','HUBLI'); ;
INSERT INTO LIBRARY_PROGRAMME VALUES(12,'KUVEMPUNAGAR','MYSURU');
INSERT INTO LIBRARY_PROGRAMME VALUE(13,'RAJAJINAGAR','BANGALORE');
INSERT INTO LIBRARY_PROGRAMME VALUES (14,'MANIPAL','UDUPI');

SELECT * FROM BOOK;

BOOK_ID TITLE PUB_YEAR PUBLISHER_NAME


1 DBMS Jan-2017 MCGRAW-HILL
2 ADBMS Jun-2017 MCGRAW-HILL
3 CD Sep-2016 PEARSON
4 ALGORITHMS Sep-2015 MIT
5 OS May-2016 PEARSON

SELECT * FROM BOOK_AUTHORS;

AUTHOR_NAME BOOK_ID
NAVATHE 1
NAVATHE 2
ULLMAN 3
CHARLES 4
GALVIN 5

SELECT * FROM PUBLISHER;

NAME PHONE ADDRESS


MCGRAW-HILL 9989076587 BANGALORE
MIT 7756120238 BANGALORE
PEARSON 9889076565 NEWDELHI
PRENTICE HALL 7455679345 HYEDRABAD
WILEY 8970862340 CHENNAI

SELECT * FROM BOOK_COPIES;

NO_OF_COPIES BOOK_ID PROGRAMME_ID


10 1 10
5 1 11
2 2 12
5 2 13
7 3 14
1 5 10
3 4 11
SELECT * FROM BOOK_LENDING;

DATEOUT DUEDATE BOOKID PROGRAMME_ID CARDNO


2017-01-01 2017-06-01 1 10
2017-01-11 2017-03-11 3 4 101
2017-02-21 2017-04-21 2 13 101
2017-03-15 2017-07-15 4 11 101
2017-04-12 2017-05-12 1 11 104

SELECT * FROM CARD;

CARDNO
101
102
103
104
105

SELECT * FROM LIBRARY_PROGRAMME;

PROGRAMME_ID PROGRAMME_NAME ADDRESS


10 VIJAY NAGAR MYSURU
11 VIDYANAGAR HUBLI
12 KUVEMPUNAGAR MYSURU
13 RAJAJINAGAR BANGALORE
14 MANIPAL UDUPI
Queries:
1. Retrieve details of all books in the library id, title, name of publisher, authors,
number of copies in each branch, etc.
SELECT B.BOOK_ID, B.TITLE, B.PUBLISHER_NAME, A.AUTHOR_NAME,
C.NO_OF_COPIES, L.PROGRAMME_ID FROM BOOK B, BOOK_AUTHORS A, BOOK_COPIES
C, LIBRARY_PROGRAMME L WHERE B.BOOK_ID=A.BOOK_ID AND
B.BOOK_ID=C.BOOK_ID AND L.PROGRAMME_ID=C.PROGRAMME_ID;

BOOK_ TITLE PUBLISHER_ AUTHOR_ NO_ PROGRAMME


ID NAME NAME OF_COPIES _ID
1 DBMS MCGRAW-HILL NAVATHE 10 10

1 DBMS MCGRAW-HILL NAVATHE 5 11


NAVATHE 2 12
2 ADBMS MCGRAW-HILL
2 ADBMS MCGRAW-HILL NAVATHE 5 13

3 CD PEARSON ULLMAN 7 14

4 ALGORITHMS MIT CHARLES 1 11

5 OS PEARSON GALVIN 3 10

2. Get the particulars of borrowers who have borrowed more than 3 books, but from
Jan 2017 to Jun 2017.
SELECT CARD_NO FROM BOOK_LENDING WHERE DATE_OUT
BETWEEN '2017-01-01'AND '2017-07-01' GROUP BY CARD_NO HAVING COUNT(*)>3;

3. Delete a book in BOOK table. Update the contents of other tables to reflect this data
manipulation operation.

DELETE FROM BOOK WHERE BOOK_ID=3;

4. Partition the BOOK table based on year of publication. Demonstrate its working
with a simple query.
CREATE VIEW VW_PUBLICATION AS SELECT PUB_YEAR FROM BOOK;

SELECT * FROM VW_PUBLICATION;

6. Create a view of all books and its number of copies that are currently available in

the Library.

CREATE VIEW VW_BOOKS AS SELECT B.BOOK_ID, B.TITLE, C.NO_OF_COPIES


FROM BOOK B, BOOK_COPIES C, LIBRARY_PROGRAMME L WHERE
B.BOOK_ID=C.BOOK_ID AND C.PROGRAMME_ID=L.PROGRAMME_ID;
SELECT * FROM VW_BOOKS;
PROGRAM-2

ORDER DATABASE:
2 Discuss the various concepts on constraints and update operations.

Consider the following schema for Order Database:

 SALESMAN(Salesman_id, Name, City, Commission)


 CUSTOMER (Customer_id, Cust_Name, City, Grade, Salesman_id)
ORDERS (Ord_No, Purchase_Amt, Ord_Date, Customer_id, Salesman_id)

Write SQL queries to:

1Count the customers with grades above Bangalore’s average.


2 Find the name and numbers of all salesman who had more than one customer.
3 List all the salesman and indicate those who have and do not have customers in their cities (Use
UNION operation.)
4 Create a view that finds the salesman who has the customer with the highest order of a day.
Demonstrate the DELETE operation by removing salesman with id 1000. All his orders must also be
deleted.

SOLUTION: ENTITY RELATIOSHIP DIAGRAM


Schema Diagram

Table Creation

CREATE TABLE SALESMAN (


SALESMAN_ID INT (4) PRIMARY KEY,
NAME VARCHAR (20),
CITY VARCHAR (20),
COMMISSION VARCHAR (20));

CREATE TABLE CUSTOMER (


CUSTOMER_ID INT (5) PRIMARY
KEY, CUST_NAME VARCHAR (20),
CITY VARCHAR (20), GRADE INT (4),
SALESMAN_ID INT (6),
FOREIGN KEY (SALESMAN_ID) REFERENCES SALESMAN (SALESMAN_ID) ON DELETE
SET NULL);

CREATE TABLE ORDERS (


ORD_NO INT (5) PRIMARY KEY,
PURCHASE_AMT DECIMAL (10, 2),
ORD_DATE DATE,
CUSTOMER_ID INT (4),
SALESMAN_ID INT (4),
FOREIGN KEY (CUSTOMER_ID) REFERENCES CUSTOMER (CUSTOMER_ID) ON DELETE
CASCADE,FOREIGN KEY (SALESMAN_ID) REFERENCES SALESMAN (SALESMAN_ID) ON
DELETE CASCADE);
Table Descriptions

DESC SALESMAN;

DESC CUSTOMER;

DESC ORDERS;

Insertion of Value

INSERT INTO SALESMAN VALUES(101,'RICHARD','LOS ANGELES','18%');


INSERT INTO SALESMAN VALUES(103,'GEORGE','NEWYORK','32%');
INSERT INTO SALESMAN VALUES(110,'CHARLES','BANGALORE','54%');
INSERT INTO SALESMAN VALUES(122,'ROWLING','PHILADELPHIA','46%');
INSERT INTO SALESMAN VALUES(126,'KURT','CHICAGO','52%');
INSERT INTO SALESMAN VALUES(132,'EDWIN','PHOENIX','41%');

INSERT INTO CUSTOMER VALUES(501,'SMITH','LOS ANGELES',10,103); INSERT INTO


CUSTOMER VALUES(510,'BROWN','ATLANTA',14,122); INSERT INTO CUSTOMER
VALUES(522,'LEWIS','BANGALORE',10,132); INSERT INTO CUSTOMER
VALUES(534,'PHILIPS','BOSTON',17,103); INSERT INTO CUSTOMER
VALUES(543,'EDWARD','BANGALORE',14,110); INSERT INTO CUSTOMER
VALUES(550,'PARKER','ATLANTA',19,126);

INSERT INTO ORDERS VALUES(1,1000, '2017-05-04',501,103);


INSERT INTO ORDERS VALUES(2,4000,'2017-01- ,522,132);
INSERT INTO ORDERS VALUES(3,2500, '2017-02-24',550,126);
INSERT INTO ORDERS VALUES(5,6000,'2017-04-13',522,103);
INSERT INTO ORDERS VALUES(6,7000, '2017-03-09',550,126);
INSERT INTO ORDERS VALUES (7,3400,'2017-01-20',501,122);

SELECT * FROM SALESMAN;

SELECT * FROM CUSTOMER;

SELECT * FROM ORDERS;


Queries
1. average.
SELECT GRADE, COUNT (CUSTOMER_ID)
FROM CUSTOMER GROUP BY GRADE
HAVING GRADE > (SELECT AVG (GRADE)
FROM CUSTOMER WHERE
CITY='BANGALORE');

SELECT GRADE,COUNT(DISTINCT CUSTOMER_ID)


FROM CUSTOMER GROUP BY GRADE
HAVING GRADE >(SELECT AVG(GRADE) FROM CUSTOMER
WHERE CITY='BANGALORE');

2. Find the name and numbers of all salesmen who had more than one customer.
SELECT SALESMAN_ID,NAME
FROM SALESMAN A
WHERE 1 <(SELECT COUNT(*) FROM CUSTOMER
WHERE SALESMAN_ID=A.SALESMAN_ID)
OR
SELECT S.SALESMAN_ID,NAME, FROM
CUSTOMER C,SALESMAN S WHERE
S.SALESMAN_ID=C.SALESMAN_ID GROUP BY
C.SALESMAN_ID HAVING COUNT(*)>1

3. their cities
(Use UNION operation.)

SELECT S.SALESMAN_ID,NAME,CUST_NAME,COMMISSION FROM SALESMAN


S,CUSTOMER C
WHERE S.CITY = C.CITY
UNION
SELECT SALESMAN_ID, NAME, 'NO MATCH',COMMISSION FROM SALESMAN
WHERE NOT CITY = ANY (SELECT CITY
FROM CUSTOMER) ORDER BY 2 DESC;
INTRODUCTION TO DBMS LAB 22ADL47
4. Create a view that finds the salesman who has the customer with the highest order of
a day.
CREATE VIEW VW_ELITSALESMAN AS
SELECT B.ORD_DATE,A.SALESMAN_ID,A.NAME FROM SALESMAN A, ORDERS B
WHERE A.SALESMAN_ID = B.SALESMAN_ID AND B.PURCHASE_AMT=(SELECT
MAX(PURCHASE_AMT) FROM ORDERS C
WHERE C.ORD_DATE = B.ORD_DATE);

SELECT * FROM VW_ELITSALESMAN

5. Demonstrate the DELETE operation by removing salesman with id 1000. All his
orders must also be deleted.
Use ON DELETE CASCADE at the end of foreign key definitions while creating child table
orders and then execute the following:

DELETE FROM SALESMAN WHERE SALESMAN_ID=101;

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 19


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47

PROGRAM-3

3 Consider the schema for Movie Database:


ACTOR (Act_id, Act_Name, Act_Gender)
DIRECTOR (Dir_id, Dir_Name, Dir_Phone)
MOVIES (Mov_id, Mov_Title, Mov_Year, Mov_Lang, Dir_id)
MOVIE_CAST (Act_id, Mov_id, Role)
RATING (Mov_id, Rev_Stars) Write SQL queries to

1. List the titles of all movies directed by


2. Find the movie names where one or more actors acted in two or more movies.
3. List all actors who acted in a movie before 2000 and also in a movie after
2015 (use JOIN operation).
4. Find the title of movies and number of stars for each movie that has at least
one rating and find the highest number of stars that movie received. Sort the
result by movie title.
5. 5.

Solution:
Entity-Relationship Diagram

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 20


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47

SCHEMA DIAGRAM

Table Creation
CREATE TABLE ACTOR (
ACT_ID INT (5) PRIMARY KEY,
ACT_NAME VARCHAR (20),
ACT_GENDER CHAR (1));

CREATE TABLE DIRECTOR (


DIR_ID INT (5) PRIMARY KEY,
DIR_NAME VARCHAR (20),
DIR_PHONE BIGINT);

CREATE TABLE MOVIES


(MOV_ID INT (4) PRIMARY KEY,
MOV_TITLE VARCHAR (50),
MOV_YEAR INT (4),
MOV_LANG VARCHAR (20),
DIR_ID INT (5),
FOREIGN KEY (DIR_ID) REFERENCES DIRECTOR(DIR_ID));

CREATE TABLE MOVIES_CAST (


ACT_ID INT (5),
MOV_ID INT (5),
ROLE VARCHAR (20),
PRIMARY KEY (ACT_ID, MOV_ID),
FOREIGN KEY (ACT_ID) REFERENCES ACTOR (ACT_ID), FOREIGN KEY
(MOV_ID)REFERENCES MOVIES (MOV_ID));

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 21


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47

CREATE TABLE RATING (


MOV_ID INT (5) PRIMARY KEY,
REV_STARS VARCHAR (25),
FOREIGN KEY (MOV_ID) REFERENCES MOVIES (MOV_ID));

Insertion of Values to Tables


INSERT INTO ACTOR VALUES (
INSERT INTO ACTOR VALUES
( INSERT INTO ACTOR VALUES (
INSERT INTO ACTOR VALUES (

9563400156);
INSERT INTO DIRECTOR VALUES(102,'ALAN TAYLOR',9971960035);
25);
75);
INSERT INTO DIRECTOR VALUES (105,'HITCHCOCK',7766138911);
INSERT INTO DIRECTOR VALUES (106,'STEVEN SPIELBERG',9966138934);

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 22


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47

INSERT INTO MOVIES VALUES (501,'JAB HARRY MET SEJAL',2017,'HINDI',104);


INSERT INTO MOVIES VALUES (502,'RAJAKUMARA',2017,'KANNADA',103);
INSERT INTO MOVIES VALUES (503,'JOLLY LLB 2', 2013,'HINDI', 100);
INSERT INTO MOVIES VALUES (504,'TERMINATOR GENESYS',2015,'ENGLISH',102);
INSERT INTO MOVIES VALUES (505,'JAWS',1975,'ENGLISH',106);
INSERT INTO MOVIES VALUES (506,'BRIDGE OF SPIES',2015,'ENGLISH', 106);
INSERT INTO MOVIES VALUES (507,'VERTIGO',1943,'ENGLISH',105);
INSERT IN

INSERT INTO MOVIES_CAST VALUES (1, 501,'HEROINE');


INSERT INTO MOVIES_CAST VALUES (1, 502,'HEROINE');
INSERT INTO MOVIES_CAST VALUES (3, 503,'COMEDIAN');
INSERT INTO MOVIES_CAST VALUES (4, 504,'GUEST');
INSERT INTO MOVIES_CAST VALUES (4, 501,'HERO');

INSERT INTO RATING VALUES (501, 4);


INSERT INTO RATING VALUES (502, 2);
INSERT INTO RATING VALUES (503, 5);
INSERT INTO RATING VALUES (504, 4);
INSERT INTO RATING VALUES (505, 3);
INSERT INTO RATING VALUES (506, 2);

SELECT * FROM ACTOR;

ACT_ID ACT_NAME ACT


1 MADHURI DIXIT F
2 AAMIR KHAN M
3 JUHI CHAWLA F
4 SRIDEVI F

SELECT * FROM DIRECTOR;

DIR_ID DIR_NAME DIR_PHONE


100 SUBHASH KAPOOR 56340015
102 ALAN TAYLOR 719600310
103 SANTHOSH ANANDDRAM 99346111
104 IMTIAZ ALI 85399209
105 HITCHCOCK 7766138911
106 STEVEN SPIELBERG 9966138934

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 23


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47

SELECT * FROM MOVIES;

MOV_ID MOV_TITLE MOV_YEAR MOV_LANG DIR_ID


501 JAB HARRY MET SEJAL 2017 HINDI 104
502 RAJAKUMARA 2017 KANNADA 103
503 JOLLY LLB 2 2013 HINDI 100
504 TERMINATOR GENESYS 2015 ENGLISH 102
505 JAWS 1975 ENGLISH 106
506 BRIDGE OF SPIES 2015 ENGLISH 106
507 VERTIGO 1958 ENGLISH 105
508 SHADOW OF A DOUBT 1943 ENGLISH 105
SELECT * FROM MOVIE_CAST;

MOV_ID MOV_TITLE MOV_YEAR MOV_LANG DIR_ID


501 JAB HARRY MET SEJAL 2017 HINDI 104
502 RAJAKUMARA 2017 KANNADA 103
503 JOLLY LLB 2 2013 HINDI 100
504 TERMINATOR GENESYS 2015 ENGLISH 102
505 JAWS 1975 ENGLISH 106
506 BRIDGE OF SPIES 2015 ENGLISH 106
507 VERTIGO 1958 ENGLISH 105
508 SHADOW OF A DOUBT 1943 ENGLISH 105

SELECT * FROM RATING;

MOV_ID REV_STARS
501 4
502 2
503 5
504 4
505 3
506 2
507 2
508 4

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 24


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47
Queries:
1. List the titles of all movies directed by
SELECT MOV_TITLE FROM MOVIES WHERE DIR_ID IN (SELECT DIR_ID FROM

OR
SELECT MOV_TITLE FROM MOVIES M, DIRECTOR D WHERE M.DIR_ID=D.DIR_ID
AND DIR_NAME='HITCHCOCK';

2. Find the movie names where one or more actors acted in two or more movies.
SELECT MOV_TITLE FROM MOVIES M,MOVIES_CAST MV
WHERE M.MOV_ID=MV.MOV_ID AND ACT_ID IN(SELECT ACT_ID FROM
MOVIES_CAST GROUP BY ACT_ID HAVING COUNT(ACT_ID)>1) GROUP BY
MOV_TITLE HAVING COUNT(*)>1;

3. List all actors who acted in a movie before 2000 and also in a movie after 2015 (use
JOIN operation).
SELECT ACT_NAME, MOV_TITLE, MOV_YEAR FROM ACTOR A JOIN
MOVIE_CAST C ON A.ACT_ID=C.ACT_ID INNER JOIN MOVIES M
ON C.MOV_ID=M.MOV_ID WHERE M.MOV_YEAR NOT BETWEEN 2000 AND 2015;

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 25


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47
4. Find the title of movies and number of stars for each movie that has at least one rating
and find the highest number of stars that movie received. Sort the result by movie title.
SELECT MOV_TITLE,MAX(REV_STARS) FROM MOVIES M ,RATING R WHERE
M.MOV_ID=R.MOV_ID GROUP BY MOV_TITLE HAVING MAX(REV_STARS)>0 ORDER
BY MOV_TITLE;

5. 5
UPDATE RATING SET REV_STARS=5 WHERE MOV_ID IN(SELECT MOV_ID FROM
MOVIES WHERE DIR_ID IN(SELECT DIR_ID FROM DIRECTOR
WHERE DIR_NAME='STEVEN SPIELBERG'));
OR
UPDATE RATING R, MOVIES M, DIRECTOR D SET REV_STARS=5 WHERE
R.MOV_ID=M.MOV_ID AND M.DIR_ID=D.DIR_ID AND DIR_NAME='STEVEN
SPIELBERG';

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 26


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47

PROGRAM-4
COLLEGE DATABASE

4 Introduce concepts of PLSQL and usage on the table.

Consider the schema for College Database:

 STUDENT (USN, SName, Address, Phone, Gender)


 SEMSEC (SSID, Sem, Sec)
 CLASS (USN, SSID)
 COURSE (Subcode, Title, Sem, Credits)
 IAMARKS (USN, Subcode, SSID, Test1, Test2, Test3, FinalIA)

Write SQL queries to:


4. List all the student details studying in fourth semester ‘C’ section.
5. Compute the total number of male and female students in each semester and in each section.
6. Create a view of Test1 marks of student USN ‘1BI15CS101’ in all Courses.
Calculate the Final IA (average of best two test marks) and update the corresponding table for all students.

SCHEMA DIAGRAM
DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 27
INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47

Table Creation
CREATE TABLE STUDENT (
USN VARCHAR (10) PRIMARY KEY,
SNAME VARCHAR (25),
ADDRESS VARCHAR (25),
PHONE BIGINT (10),
GENDER CHAR (1));

CREATE TABLE SEMSEC (


SSID VARCHAR (5) PRIMARY KEY,
SEM INT (5),SEC CHAR (1));

CREATE TABLECLASS
(USN VARCHAR (10),
SSID VARCHAR (5),
PRIMARY KEY (USN, SSID),
FOREIGN KEY (USN) REFERENCES STUDENT (USN),
FOREIGN KEY (SSID) REFERENCES SEMSEC (SSID));

CREATE TABLE SUBJECT(


SUBCODE VARCHAR(10) PRIMARY KEY,
TITLE VARCHAR(20),
SEM INT,
CREDITS INT);

CREATE TABLE IAMARKS


( USN VARCHAR (10),
SUBCODE VARCHAR (8),
SSID VARCHAR (5),
TEST1 INT (2),

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 28


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47

TEST2 INT (2),


TEST3 INT (2),
FINALIA INT (2),
PRIMARY KEY (USN, SUBCODE, SSID),
FOREIGN KEY (USN) REFERENCES STUDENT (USN),
FOREIGN KEY (SUBCODE) REFERENCES SUBJECT (SUBCODE), FOREIGN
KEY (SSID) REFERENCES SEMSEC (SSID));

Insertion of values to tables

INSERT INTO STUDENT VALUES ('4AD13CS020','AKSHAY','BELAGAVI', 8877881122,'M');


INSERT INTO STUDENT VALUES ('4AD13CS062','SANDHYA','BENGALURU',
7722829912,'F');
INSERT INTO STUDENT VALUES ('4AD13CS091','TEESHA','BENGALURU', 7712312312,'F');
INSERT INTO STUDENT VALUES ('4AD13CS066','SUPRIYA','MANGALURU',
8877881122,'F');
INSERT INTO STUDENT VALUES ('4AD14CS010','ABHAY','BENGALURU', 9900211201,'M');
INSERT INTO STUDENT VALUES ('4AD14CS032','BHASKAR','BENGALURU',
9923211099,'M');
INSERT INTO STUDENT VALUES ('4AD14CS025','ASMI','BENGALURU', 7894737377,'F');
INSERT INTO STUDENT VALUES ('4AD15CS011','AJAY','TUMKUR', 9845091341,'M');
INSERT INTO STUDENT VALUES ('4AD15CS029','CHITRA','DAVANGERE', 7696772121,'F');
INSERT INTO STUDENT VALUES ('4AD15CS045','JEEVA','BELLARY', 9944850121,'M');
INSERT INTO STUDENT VALUES ('4AD15CS091','SANTOSH','MANGALURU',
8812332201,'M')
INSERT INTO STUDENT VALUES ('4AD16CS045','ISMAIL','KABURGI', 9900232201,'M');
INSERT INTO STUDENT VALUES ('4AD16CS088','SAMEERA','SHIMOGA', 9905542212,'F');
INSERT INTO STUDENT VALUES ('4AD16CS122','VINAYAKA','CHIKAMAGALUR',
8800880011,'M');

INSERT INTO SEMSEC VALUES ('CSE8A', 8,'A');


INSERT INTO SEMSEC VALUES ('CSE8B', 8,'B');
INSERT INTO SEMSEC VALUES ('CSE8C', 8,'C');
INSERT INTO SEMSEC VALUES ('CSE7A', 7,'A');
INSERT INTO SEMSEC VALUES ('CSE7B', 7,'B');
INSERT INTO SEMSEC VALUES ('CSE7C', 7,'C');
INSERT INTO SEMSEC VALUES ('CSE6A', 6,'A');
INSERT INTO SEMSEC VALUES ('CSE6B', 6,'B');

INSERT INTO CLASS VALUES ('4AD13CS020','CSE8A');


INSERT INTO CLASS VALUES ('4AD13CS062','CSE8A');
INSERT INTO CLASS VALUES ('4AD13CS066','CSE8B');
INSERT INTO CLASS VALUES ('4AD13CS091','CSE8C');
INSERT INTO CLASS VALUES ('4AD14CS010','CSE7A');
INSERT INTO CLASS VALUES ('4AD14CS025','CSE7A');
INSERT INTO CLASS VALUES ('4AD14CS032','CSE7A');

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 29


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47
INSERT INTO CLASS VALUES ('4AD15CS011','CSE4A');
INSERT INTO CLASS VALUES ('4AD15CS029','CSE4A');
INSERT INTO CLASS VALUES ('4AD15CS045','CSE4B');
INSERT INTO CLASS VALUES ('4AD15CS091','CSE4C');
INSERT INTO CLASS VALUES ('4AD16CS045','CSE3A');

INSERT INTO SUBJECT VALUES ('10CS81','ACA', 8, 4);


INSERT INTO SUBJECT VALUES ('10CS82','SSM', 8, 4);
INSERT INTO SUBJECT VALUES ('10CS83','NM', 8, 4);
INSERT INTO SUBJECT VALUES ('10CS84','CC', 8, 4);
INSERT INTO SUBJECT VALUES ('10CS85','PW', 8, 4);
INSERT INTO SUBJECT VALUES ('10CS71','OOAD', 7, 4);

INSERT INTO IAMARKS VALUES ('4AD13CS091','10CS81','CSE8C', 15, 16, 18,0);


INSERT INTO IAMARKS VALUES ('4AD13CS091','10CS82','CSE8C', 12, 19, 14,0);
INSERT INTO IAMARKS VALUES ('4AD13CS091','10CS83','CSE8C', 19, 15, 20,0);
INSERT INTO IAMARKS VALUES ('4AD13CS091','10CS84','CSE8C', 20, 16, 19,0);
INSERT INTO IAMARKS VALUES ('4AD13CS091','10CS85','CSE8C', 15, 15, 12,0);

SELECT * FROM STUDENT;

SELECT * FROM

SELECT * FROM SEMSEC;

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 30


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47

SELECT * FROM CLASS;

SELECT * FROM SUBJECT;

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 31


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47

SELECT * FROM IAMARKS;

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 32


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 33


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47
Queries:
1. section.

SELECT S.*, SS.SEM, SS.SEC FROM STUDENT S, SEMSEC SS, CLASS C WHERE

2. Compute the total number of male and female students in each semester and in each
section. SELECT SS.SEM, SS.SEC, S.GENDER, COUNT (S.GENDER) AS COUNT
FROM STUDENT S, SEMSEC SS, CLASS C
WHERE S.USN = C.USN AND SS.SSID = C.SSID
GROUP BY SS.SEM, SS.SEC, S.GENDER ORDER BY SEM;

3.

Subjects.

CREATE VIEW VW_STUDENT_TEST AS SELECT TEST1,SUBCODE FROM


IAMARKS WHERE USN= 4AD13CS091';

SELECT * FROM VW_STUDENT_TEST;

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 34


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47

4. Calculate the FinalIA (average of best two test marks) and update the corresponding
table for all students.
UPDATE IAMARKS
SET FINALIA=GREATEST(TEST1+TEST2,TEST2+TEST3,TEST1+TEST3)/2;

Note: Before execution above SQL statement, IAMARKS table contents are:

SELECT * FROM IAMARKS;

UPDATE IAMARKS
SET FINALIA=GREATEST(TEST1+TEST2,TEST2+TEST3,TEST1+TEST3)/2;

After executing above SQL statement, IAMARKS table contents are:

5. Categorize students based on the following criterion:


If FinalIA = 17 to 20 then CAT =

Give these details only for 8th semester A, B, and C section students.

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 35


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47

SELECT S.USN,S.SNAME,S.ADDRESS,S.PHONE,S.GENDER,
(CASE
WHEN IA.FINALIA BETWEEN 17 AND 20 THEN 'OUTSTANDING'
WHEN IA. FINALIA BETWEEN 12 AND 16 THEN 'AVERAGE'
ELSE 'WEAK'
END) AS CAT
FROM STUDENT S, SEMSEC SS, IAMARKS IA, SUBJECT SUB WHERE S.USN = IA.USN
AND SS.SSID = IA.SSID AND SUB.SUBCODE = IA.SUBCODE AND SUB.SEM = 8;

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 36


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47

PROGRAM 5
COMPANY DATABASE

5 Demonstrate the core concepts on table like nested and correlated nested queries and also EXISTS
and NOT-EXISTS keywords.

Consider the schema for Company Database:

 EMPLOYEE(SSN, Name, Address, Sex, Salary, SuperSSN, DNo)


 DEPARTMENT(DNo, DName, MgrSSN, MgrStartDate)
 DLOCATION(DNo,DLoc)
 PROJECT(PNo, PName, PLocation, DNo)
 WORKS_ON(SSN, PNo, Hours)

Write SQL queries to:


7. Make a list of all project numbers for projects that involve an employee whose last name is ‘Scott’,
either as a worker or as a manager of the department that controls the project.
8. Show the resulting salaries if every employee working on the ‘IoT’ project is given a 10 percent raise.
9. Find the sum of the salaries of all employees of the ‘Accounts’ department, as well as the maximum
salary, the minimum salary, and the average salary in this department.
10. Retrieve the name of each employee who works on all the projects controlled by department number 5
(use NOT EXISTS operator).
11. For each department that has more than five employees, retrieve the department number and the
number ofits employees who are making more than Rs. 6,00,000.

Table Creation

CREATE TABLE DEPARTMENT (


DNO VARCHAR (20) PRIMARY KEY,
DNAME VARCHAR (20),
MGRSTARTDATE DATE,
MGRSSN VARCHAR (20));

CREATE TABLE EMPLOYEE (


SSN VARCHAR (20) PRIMARY KEY,
FNAME VARCHAR (20),
LNAME VARCHAR (20),
ADDRESS VARCHAR (100),
SEX CHAR (1),
SALARY INT (10),
SUPERSSN VARCHAR (20),
DNO VARCHAR (20),
FOREIGN KEY (SUPERSSN) REFERENCES EMPLOYEE (SSN),
FOREIGN KEY (DNO) REFERENCES DEPARTMENT (DNO));

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 37


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47

NOTE: Once DEPARTMENT and EMPLOYEE tables are created we must alter department
table to add foreign constraint MGRSSN using sql command
ALTER TABLE DEPARTMENT ADD FOREIGN KEY(MGRSSN) REFERENCES
EMPLOYEE(SSN);

CREATE TABLE DLOCATION (


DLOC VARCHAR (20),
DNO VARCHAR (20),
PRIMARY KEY (DNO, DLOC),
FOREIGN KEY (DNO) REFERENCES DEPARTMENT (DNO));

CREATE TABLE PROJECT (


PNO INT (10) PRIMARY KEY,
PNAME VARCHAR (20),
PLOCATION VARCHAR (20),
DNO VARCHAR (20),
FOREIGN KEY (DNO) REFERENCES DEPARTMENT (DNO));

CREATE TABLE WORKS_ON (


HOURS INT (4),
SSN VARCHAR (20),
PNO INT (10),
PRIMARY KEY (SSN, PNO),
FOREIGN KEY (SSN) REFERENCES EMPLOYEE (SSN),
FOREIGN KEY (PNO) REFERENCES PROJECT (PNO));

Insertion of values to tables


INSERT INTO EMPLOYEE VALUES ('ATMEECE01','JOHN','SCOTT','BANGALORE','M',
450000,NULL,NULL);
INSERT INTO EMPLOYEE VALUES ('ATMECSE01','JAMES','SMITH','BANGALORE','M',
500000,NULL,NULL);
INSERT INTO EMPLOYEE VALUES ('ATMECSE02','HEARN','BAKER','BANGALORE','M',
700000,NULL,NULL);
INSERT INTO EMPLOYEE VALUES ('ATMECSE03','EDWARD','SCOTT','MYSORE','M',
500000,NULL,NULL);
INSERT INTO EMPLOYEE VALUES ('ATMECSE04','PAVAN','HEGDE','MANGALORE','M',
650000,NULL,NULL);
INSERT INTO EMPLOYEE VALUES ('ATMECSE05','GIRISH','MALYA','MYSORE','M',
450000,NULL,NULL);
INSERT INTO EMPLOYEE VALUES ('ATMECSE06','NEHA','SN','BANGALORE','F',
800000,NULL,NULL);

INSERT INTO DEPARTMENT VALUES ('1','ACCOUNTS','2001-01-01','ATMEACC02');


INSERT INTO DEPARTMENT VALUES ('2','IT','2016-08-01','ATMEIT01');
INSERT INTO DEPARTMENT VALUES ('3','ECE','2008-6-01','ATMEECE01');
INSERT INTO DEPARTMENT VALUES ('4','ISE','2015-06-01','ATMEISE01');

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 38


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47

INSERT INTO DEPARTMENT VALUES ('5','CSE','2002-06-01','ATMECSE05');

UPDATE EMPLOYEE SET DNO=’1’,SUPERSSN=NULL WHERE


SSN=’ATMEIT01’;
UPDATE EMPLOYEE SET DNO=’1’,SUPERSSN=’ATMECSE’,DNO=’1’;
WHERE SSN=’ATMEIT01’;
UPDATE EMPLOYEE SET DNO=’2’,SUPERSSN=’ATMECNE’,DNO=’2’;
WHERE SSN=’ATMEIT01’;
UPDATE EMPLOYEE SET DNO=’3’,SUPERSSN=’ATMEEEE’,DNO=’3’;
WHERE SSN=’ATMEIT01’;

INSERT INTO DLOCATION VALUES ('BANGALORE', '1');


INSERT INTO DLOCATION VALUES ('BANGALORE', '2');
INSERT INTO DLOCATION VALUES ('BANGALORE', '3');
INSERT INTO DLOCATION VALUES ('MANGALORE', '4');
INSERT INTO DLOCATION VALUES ('MANGALORE', '5');

INSERT INTO PROJECT VALUES (100,'IOT','BANGALORE','5');


INSERT INTO PROJECT VALUES (101,'CLOUD','BANGALORE','5');
INSERT INTO PROJECT VALUES (102,'BIGDATA','BANGALORE','5');
INSERT INTO PROJECT VALUES (103,'SENSORS','BANGALORE','3');
INSERT INTO PROJECT VALUES (104,'BANK MANAGEMENT','BANGALORE','1');
INSERT INTO PROJECT VALUES (105,'SALARY MANAGEMENT','BANGALORE','1');

INSERT INTO WORKS_ON VALUES (4, 'ATMECSE01', 100);


INSERT INTO WORKS_ON VALUES (6, 'ATMECSE01', 101);
INSERT INTO WORKS_ON VALUES (8, 'ATMECSE01', 102);
INSERT INTO WORKS_ON VALUES (10, 'ATMECSE02', 100);

INSERT INTO WORKS_ON VALUES (4, 'ATMECSE05', 101);

SELECT * FROM EMPLOYEE;

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 39


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47

SELECT * FROM DEPARTMENT ;

SELECT * FROM DLOCATION ;

SELECT * FROM PROJECT ;

SELECT * FROM WORKS_ON

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 40


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47

Queries:

1. Make a list of all project numbers for projects that involve an employee whose last name

(SELECT DISTINCT P.PNO FROM PROJECT P, DEPARTMENT D, EMPLOYEE E

UNION
(SELECT DISTINCT P1.PNO FROM PROJECT P1, WORKS_ON W, EMPLOYEE E1 WHERE

2.
percent raise.
SELECT E.FNAME, E.LNAME, 1.1*E.SALARY AS INCR_SAL FROM EMPLOYEE E,
WORKS_ON W, PROJECT P WHERE E.SSN=W.SSN AND W.PNO=P.PNO AND

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 41


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47

3
maximum salary, the minimum salary, and the average salary in this department
SELECT SUM (E.SALARY), MAX (E.SALARY), MIN (E.SALARY), AVG (E.SALARY)
FROM EMPLOYEE E, DEPARTMENT D WHERE E.DNO=D.DNO AND

4. Retrieve the name of each employee who works on all the projects Controlled
by department number 5 (use NOT EXISTS operator).
SELECT E.FNAME,E.LNAME FROM EMPLOYEE E WHERE NOT EXISTS
(SELECT PNO FROM PROJECT P WHERE DNO=5 AND PNO NOT IN
(SELECT PNO FROM WORKS_ON W WHERE E.SSN=SSN));

5. For each department that has more than five employees, retrieve the department
number and the number of its employees who are making more than Rs. 6,
00,000. SELECT D.DNO, COUNT (*)
FROM DEPARTMENT D, EMPLOYEE E
WHERE D.DNO=E.DNO
AND E.SALARY>600000
AND D.DNO IN (SELECT E1.DNO
FROM EMPLOYEE E1
GROUP BY E1.DNO
HAVING COUNT (*)>5)
GROUP BY D.DNO;

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 42


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 43


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
INTRODUCTION TO DBMS LAB 22ADL47

DEPARTMENT OF ARARTIFICIAL INTELLIGENCE & DATA SCIENCE Page 44


INTRODUCTION TO DATABASE MANGEMENT SYSTEM LAB
FACULTY OF ENGINEERING & TECHNOLOGY (Co-Ed),
KALABURAGI
SHARNBASVA UNIVERSITY KALABURAGI

EIOIQWOU

DEPARTMENT OF ARTIFICIAL INTELLIGENCE & DATA


SCIENCE

You might also like