Assignment 4
Objectives :- To drop a table, alter schema of a table, insert / update / delete records using tables created in previous Assignments. ( use simple forms of insert / update / delete statements)
The Drop & Alter DDL statements :
1 Drop: Deletes an object (table/view/constraint) schema fromthe database.
Syntax: Drop object-type object-name
2 Alter: ALTER TABLE command of SQL is used to modify the structure of the table It can be used
for following purposes:
a) adding new column
b) modifying existing columns
c) add an integrity constraint
d) To redefine a column
Restrictions on the alter table are that, the following tasks cannot be performed with this clause
a) Change the name of the column
b) Drop a column
c) Decrease the size of a column if table data exists
Syntax: a. Alter table tablename Add (new columnname datatype (size), new columnname
datatype(size)…);
c .Alter table tablename modify (columnname new datatype(new size),..);
Insert / update / delete DML statements:
The different DML statements with their syntax are given below:( insert / update / delete statements)
1 Insert:
The insert statement is used to insert tuples or records into a created table or a relation. We specify a
list of comma-separated column values, which must be in the same order as the columns in the table.
To insert character data we must enclose it in single quotes(‘). If a single quote is part of the string
value to be inserted, then precede it with a backslash(\).When we don’t have values for every column
in the table, or the data given in insert is not in the same column order as in the table, then we specify
the column names also along with the values (2nd syntax).
Syntax: INSERT INTO tablename VALUES (list of column values);
INSERT INTO tablename(list of column names) VALUES (list of column values
corresponding to the column names );
2. Update:
The UPDATE command is used to change or modify data values in a table. To specify update of
several columns at the same time, we simply specify them as a comma separated list.
Syntax: UPDATE tablename
SET columnname = value where condition;
3.Delete: The DELETE statement is used to remove data from tables.
Syntax: DELETE FROM table name where condition;
Set A
The Drop & Alter DDL statements
1. Consider the employee table created in assignment 3 and add designation column in the employee table with values restricted to a set of values.
Query:-
Query to create Employee table :-
Create Table Employee (Employee_id int primary key ,
Employee_name varchar(20) NOT NULL CHECK (Employee_name = upper (Employee_name )), Employee_desig varchar(10) CHECK (Employee_desig IN ('Manager', 'staff', 'worker')),Employee_sal float CHECK (Employee_sal >0), Employee_uid int Unique ,
Constraint Emp_id CHECK(Employee_uid <> Employee_id ));
CREATE TABLE
Alter table Employee Add designation varchar(20) check(designation in ('manager','Accountant','Employee')) ;
2. Create table student( student_no, sname, date_of_birth). Add new column into student relation named address as a text data type with NOT NULL integrity constraint and a column phone of data type integer.
Query:- Create table Student (sno int primary key , sname varchar(50) , date_of_birth date);
Alter table Student add address text NOT NULL,add phone integer;
3. Consider the project relation created in the assignment 2. Add a constraint that the project name should always start with the letter ‘R’
Query:-
Create Project table If not avaoilabale as :
Create table Project(pno int primary key, pname varchar(50), status boolean );
Alter table Project add constraint pname_chk check (pname like 'R%') ;
4. Consider the relation hospital created in assignment 2. Add a column hbudget of type int , with the constraint that budget of any hospital should always > 50000.
Query:-
Create table Hospital if not available as:-
Create table Hospital(hno int primary key , name varchar(50), city varchar(10));
Alter table hospital add (new hbudget int CHECK (hbudget >50000));
Insert / update / delete DML statements:
1. Create the following tables ( primary keys are underlined.).
Property(pno ,description, area)
Owner(oname , address ,phone)
An owner can have one or more properties, but a property belongs to exactly one owner . Create the relations accordingly ,so that the relationship is handled properly and the relations are in normalized form (3NF).
a) Insert two records into owner table.
b) insert 2 property records for each owner .
c) Update phone no of “Mr. Nene” to 9890278008
d) Delete all properties from “pune” owned by “ Mr. Joshi”
Queries:-
Create table Owner (oname varchar(50) primary key , address text, phone integer );
Create table Property (pno int primary key , descr text, area varchar(50), oname varchar(50) references Owner(oname) on delete cascade on update cascade );
a) Insert into Owner values('Mr. Nene', 'pune' , 8822446633);
Insert into Owner values('Mr. Sane', 'Nashik' , 9563214785);
Insert into Owner values('Mr. Joshi', 'pune' , 8754123695);
Insert into Owner values('Mr. Sathe', 'Mumbai' , 7744556633);
b) Insert into Property Values( 101, 'new Bungalow', 'pune' ,'Mr. Joshi');
Insert into Property Values( 102, 'new House', 'pune' ,'Mr. Joshi');
Insert into Property Values( 103, 'Old Bungalow', 'Nashik' ,'Mr. Sane');
Insert into Property Values( 104, 'new Bungalow', 'Nashik' ,'Mr. Sane');
select * from Owner;
oname | address | phone
-----------+---------+------------
Mr. Nene | pune | 8822446633
Mr. Sane | Nashik | 9563214785
Mr. Joshi | pune | 8754123695
Mr. Sathe | Mumbai | 7744556633
(4 rows)
select * from Property;
pno | descr | area | oname
-----+--------------+--------+-----------
101 | new Bungalow | pune | Mr. Joshi
102 | new House | pune | Mr. Joshi
103 | Old Bungalow | Nashik | Mr. Sane
104 | new Bungalow | Nashik | Mr. Sane
(4 rows)
c) update Owner set phone=9890278008 where oname='Mr. Nene';
sample=# select * from Owner;
oname | address | phone
-----------+---------+------------
Mr. Sane | Nashik | 9563214785
Mr. Joshi | pune | 8754123695
Mr. Sathe | Mumbai | 7744556633
Mr. Nene | pune | 9890278008
d) delete from Owner where address='pune' and oname='Mr. Joshi';
sample=# select * from Owner;
oname | address | phone
-----------+---------+------------
Mr. Sane | Nashik | 9563214785
Mr. Sathe | Mumbai | 7744556633
Mr. Nene | pune | 9890278008
2 . Create the following tables ( primary keys are underlined).
Emp(eno, ename , designation, sal)
Dept(dno, dname, dloc)
There exists a one-to-many relationship between emp & dept.
Create the Relations accordingly, so that the relationship is handled properly and the relations are in normalized form (3NF).
a) Insert 5 records into department table
b) Insert 2 employee records for each department.
c) increase salary of “managers” by 15%;
d) delete all employees of department 30;
e) delete all employees who are working as a “clerk”
f) change location of department 20 to ‘KOLKATA’
create table dept (dno int primary key,dname text,dloc text);
create table emp(dno int,eno int primary key,ename text,designation text,sal money,
foreign key (dno) references dept (dno) on delete cascade );
a]
insert into dept values(11,'computer','pune');
insert into dept values(22,'computer1','pune');
insert into dept values(33,'computer2','pune');
insert into dept values(44,'computer3','pune');
insert into dept values(55,'computer4','pune');
b]
insert into emp values(11,1,'xyz','manager',7000);
insert into emp values(11,2,'xyz','staff',7000);
insert into emp values(22,3,'pqr','clerk',2000);
sample=# select * from dept;
dno | dname | dloc
-----+-----------+------
11 | computer | pune
22 | computer1 | pune
33 | computer2 | pune
44 | computer3 | pune
55 | computer4 | pune
(5 rows)
sample=# select * from emp;
dno | eno | ename | designation | sal
-----+-----+-------+-------------+-----------
11 | 1 | xyz | manager | ₹7,000.00
11 | 2 | xyz | staff | ₹7,000.00
22 | 3 | pqr | clerk | ₹2,000.00
(3 rows)
c] update emp set sal=sal*15/100 where designation='manager';
sample=# select * from emp;
dno | eno | ename | designation | sal
-----+-----+-------+-------------+-----------
11 | 2 | xyz | staff | ₹7,000.00
22 | 3 | pqr | clerk | ₹2,000.00
11 | 1 | xyz | manager | ₹1,050.00
(3 rows)
d] delete from emp where dno=11;
sample=# select * from emp;
dno | eno | ename | designation | sal
-----+-----+-------+-------------+-----------
22 | 3 | pqr | clerk | ₹2,000.00
(1 row)
e] delete from emp where designation='clerk';
f] update dept set dloc='KOLKATA' where dno=20;
sample=# select * from dept;
dno | dname | dloc
-----+-----------+---------
11 | computer | pune
33 | computer2 | pune
44 | computer3 | pune
55 | computer4 | pune
22 | computer1 | KOLKATA
Set B
The Drop & Alter DDL statements
1. Create table driver (licence_no, Name, Address) and perform the following queries
1. Add new column age with constraint that age should be greater than 20 years.
2. Alter table by modifying driver_name to varchar(50));
3. Alter table driver ,drop the column age.
4. Remove the driver table from the database.
Queries:-
Create table Driver (licence_no int primary key , Name varchar(20) , address text);
1) Alter table Driver add age int CHECK ( age > 20);
2) alter table Driver alter column Name Type varchar(50);
3) alter table Driver drop age;
4) drop table Driver;
2. Create table Game (name, no-of-players, captain_name) and perform the following queries
1. Add new column game_no with constraint primary key.
2. Alter table by adding constraint uppercase to captain_name.
3. Modify table by adding the column game_duration.
4. Add column game_type with values cricket,hockey,tennis.
5. Remove game table from the database
Queries:-
Create table Game (name varchar(50), no_of_players int , captain_name varchar(50));
1) alter table Game add game_no int primary key;
2) Alter table Game add constraint cap_name_chk CHECK(captain_name = upper(captain_name ));
3) Alter table Game add game_duration int;
4) Alter table Game add game_type varchar(20) CHECK( game_type IN ( 'cricket' , 'hockey' , 'tennis' ));
5) Drop table Game;
stud_id | stud_name | s_address | status
---------+-----------+-----------+--------
101 | Ashok | Nashik | pass
102 | Asha | Pune | pass
103 | Alok | Nashik | fail
104 | Kartik | Mumbai | pass
105 | Sonali | Pune | fail
(5 rows)
sample=# select * from Teacher;
teacher_id | tname | t_address
------------+--------+-----------
201 | Sarika | Nashik
202 | Akshay | Mumbai
203 | Amar | Pune
204 | Ankita | Pune
(4 rows)
sample=# select * from Subject;
subject_id | subject_name | teacher_id
------------+--------------+------------
301 | maths | 201
302 | Drawing | 203
303 | Electronics | 202
304 | Stats | 204
(4 rows)
sample=# select * from Stud_subj;
stud_id | subject_id | marks | grade
---------+------------+-------+-------
101 | 301 | 50 | B
104 | 302 | 80 | O
102 | 303 | 60 | A
103 | 304 | 90 | O
(4 rows)
where Subject_id = (select Subject_id from Subject
Where subject_name ='maths')
and stud_id =(select stud_id from Student
where stud_name='Ashok');
No comments:
Post a Comment