DDL COMMANDS
Create Table :
SQL>    create table employee (
       empid varchar(10) primary key,
       empname varchar(20) not null,
       gender varchar(7) not null,
       age number(3) not null,
       dept varchar(15) not null,
       dob date not null,
       doj date not null );
  Table created.
SQL>     create table salary (
       empid varchar(10) references employee(empid),
       salary number(10) not null,
       dept varchar(15) not null,
       branch varchar(20) not null );
  Table created.
SQL>    create table branchtable (
       branch varchar(20) not null,
       city varchar(20) not null);
 Table created.
Describe Table:
SQL> desc employee;
      Name Null? Type
      EMPID NOT NULL VARCHAR(10)
      EMPNAME NOT NULL VARCHAR(20)
      GENDER NOT NULL VARCHAR(7)
      AGE NOT NULL NUMBER(3)
      DEPT NOT NULL VARCHAR(15)
      DOB NOT NULL DATE
      DOJ NOT NULL DATE
SQL> desc salary;
      Name Null? Type
      EMPID SALARY NOT NULL
      VARCHAR (10)
      NUMBER (10)
      DEPT NOT NULL VARCHAR (15)
      BRANCH NOT NULL VARCHAR (20)
SQL> desc branchtable;
      Name Null? Type
      BRANCH NOT NULL VARCHAR2 (20)
      CITY NOT NULL VARCHAR2 (20)
Alter Table:
ADD:
SQL> alter table employee add(designation varchar2(15));
Table altered.
SQL> alter table salary add(constraint nithi unique(empid));
Table altered.
MODIFY:
SQL> alter table employee modify (designation varchar2(20));
Table altered.
RENAME TABLE:
SQL>     create table emp (
       empid varchar(10),
       empname varchar(20),
       age number(3),
       sex char);
Table created.
SQL> rename emp to empl;
Table renamed.
SQL> desc emp;
ERROR: ORA-04043: object emp does not exist
Table altered.
TRUNCATE TABLE DATA:
SQL> truncate table emp;
Table truncated.
SQL> select * from emp;
No rows selected
SQL> commit;
Commit complete.
DROP TABLE:
SQL> drop table empl;
Table dropped.
SQL> desc empl;
ERROR:
ORA-04043: object empl does not exist
                             DML COMMANDS
TABLE CREATION:
SQL> CREATE TABLE employee(e_no number(10),
      e_name varchar(15),
      e_age number(5),
      d_no number(10),
      salary number(10));
Table created.
INSERTION:
SQL> insert into employee values (&e_no,'&e_name', &e_age, &d_no,&salary);
Enter value for e_no: 5025
Enter value for e_name: John
Enter value for e_age: 21
Enter value for d_no: 02
Enter value for salary: 35000
Old 1: values (&e_no,'&e_name', &e_age, &d_no, &salary)
New 1: values (1,'John', 22, 02, 35000)
1 row created.
SQL> select * from employee;
      E_NO       E_NAME         E_AGE     D_NO   SALARY
      5025        John           21       02     35000
      5032        Jithin         20       02     20000
      5033        Midhu          19        03     20000
      5047        Stephen        20        01     25000
UPDATE:
SQL> UPDATE employee SET e_name=’ Midhun’ WHERE e_no=5033;
Updated.
SQL> select * from employee;
      E_NO    E_NAME       E_AGE     D_NO   SALARY
      5025       John          21    02     35000
      5032      Jithin         20    02     20000
      5033      Midhun          19     03   20000
      5047      Stephen        20     01     25000
DELETE:
SQL> DELETE from employee WHERE employee=5001;
Deleted.
SQL> select * from employee;
      E_NO    E_NAME       E_AGE     D_NO   SALARY
      5025       John          21    02     35000
      5032      Jithin         20    02     20000
      5033      Midhun         19    03     20000
      5047      Stephen        20    01      25000
         SQL QUERIES: QUERIES, SUB QUERIES, AGGREGATE FUNCTION
                         E_id    E_name          Age         Salary
                         101          Anu         22         9000
                         102         Shane        29         8000
                         103         Rohan       34          6000
                         104         Scott       44          10000
                         105         Tiger       35          8000
                         106         Alex        27          7000
                         107         Abhi        29          8000
Create Employee table containing all Records:
SQL> create table emp(eid number,ename varchar2(10),age number,salary number);
Table created.
Count number of employee names from employee table:
SQL> select count(ename) from emp;
                                     COUNT(ENAME)
                                 -------------------------
                                             7
Find the Maximum age from employee table:
SQL> select max(age) from emp;
                                  MAX(AGE)
                                 -----------------
                                       44
Find the Minimum age from employee table:
SQL> select min(age) from emp;
                                  MIN(AGE)
                                 ----------------
                                       22
Display the Sum of age employee table:
SQL> select sum(age) from emp;
                                  SUM(AGE)
                                 ----------------
                                      220
Display the Average of age from Employee table:
SQL> select avg(age) from emp;
                                  AVG(AGE)
                                 ----------------
                                 31.4285714
Create a View for age in employee table:
SQL> create or replace view A as select age from emp where age <30;
View created.
Display views:
SQL> select * from A;
                                           AGE
                                       -------------
                                            22
                                            29
                                            27
                                            29
Find grouped salaries of employees(group by clause):
SQL> select salary from emp group by salary;
                                         SALARY
                                       --------------
                                          9000
                                         10000
                                          8000
                                          6000
                                          7000
Find salaries of employee in Ascending Order(order by clause):
SQL> select ename,salary from emp order by salary;
                                   ENAME         SALARY
                                  ------------ -------------
                                     rohan       6000
                                      alex       7000
                                      shane      8000
                                      abhi       8000
                                      tiger      8000
                                      anu       9000
                                     scott      10000
7 rows selected.
Having Clause:
SQL> select ename,salary from emp where age<29 group by ename,salary having
salary<10000;
                                   ENAME        SALARY
                                 ------------- --------------
                                     Alex         7000
                                     anu          9000
                      EXCEPTIONAL HANDLING
Query 01: Create a emp table:
SQL> create table emp(
      eno number(4),
      salary number(6,2));
Table created.
Query 02: Insert records in the emp table:
Enter value for eno: 123
Enter value for salary: 5000
old 1: insert into emp values(&eno,&salary)
new 1: insert into emp values(123,5000)
1 row created.
Old values
                                      ENO SALARY
                                       123    5400
                                       124    6000
                                       125    4700
Procedure:
SQL> declare
      empno number(4):='&empno';
      sal number(6,2);
     sal_missing exception;
     begin
     select salary into sal from emp where eno=empno;
     if sal is NULL then
     raise sal_missing;
     end if;
     if sal<2000 then
     sal:=sal+sal*(5/100);
     elsif sal<5000 then 13 sal:=sal+sal*(6/100);
     elsif sal<1000 then 15 sal:=sal+sal*(7/100);
     elsif sal>1000 then 17 sal:=sal+sal*(8/100);
     end if;
     update emp set salary=sal where empno=eno;
     exception
     when sal_missing then
     dbms_output.put_line('Salary is null');
     when no_data_found then
     dbms_output.put_line('Invalidempno');
     end;
Enter value for empno: 125
old 2: empno number(4):='&empno';
new 2: empno number(4):='125'; PL/SQL procedure successfully completed.
Output:
New values
                                    ENO    SALARY
                                    123      5400
                                    124      6000
                                    125      4982
                                     CURSOR
program to demonstrate Cursors:
SQL> create table emp(
      eno number(4),
      sal number(6,2)
      ename varchar(20)
      job varchar(20));
Table created.
SQL>declare
      cursor c11 is
      select * from emp order by sal,job;
      cval emp%rowtype;
      begin
      dbms_output.put_line('empno '||'ename');
      open c11;
      loop
      fetch c11 into cval;
      exit when c11%rowcount=10;
      dbms_output.put_line(cval.empno||' '||cval.ename);
      end loop;
      close c11;
      end;
Output:
          Empno   ename
          69000   JULIUS
          63679   SANDRINE
          68736   ADNRES
          69324   MARKER
          69924   MARKER
          67832   CLARE
          66928    BLAZE
          65646   JONAS
          67858   SCARLET
                                    TRIGGERS
SQL> create table emp(
       eno number(4),
       sal number(6,2)
       ename varchar(20)
      job varchar(20));
Table created.
SQL>create or replace trigger t11
      before update on emp for each row
      begin
      if :new.sal<1000
      then
      dbms_output.put_line('trigger fired');
      end if;
      end;
Trigger created.
Trigger gets fired when update is performed on EMP table
SQL> update emp
      set sal=500
      where eno=69000;
Output:
Trigger fired
1 row updated.
                                 PACKAGES
Creating package specification:
CREATE or replace PACKAGE emppackage AS
procedure emp_proc2;
function fname2(a in number,b in out number)
return number;
end;
Creating package definition or body:
CREATE or replace PACKAGE body emppackage AS
procedure emp_proc2
is
begin
update emp
set sal=sal+sal*0.10
where comm<>sal*0.09;
DBMS_OUTPUT.PUT_LINE ('I am a procedure ');
end emp_proc2;
function fname2(a in number,b in out number)
return number is
begin
b:=a;
return b;
end fname2;
END;
Calling function / procedure of a package in a program:
declare
a number:=10;
b number:=10;
begin
a:=emppackage.fname2(20,b);
dbms_output.put_line(a || b);
emppackage.emp_proc2;
end;
Output:
2020
I am a procedure
                       LIBRARY MANAGEMENT:
Query 01: Create a library table:
SQL> create table library(
      book_no number(3),
      book_title varchar2(15),
      book_auth varchar2(15),
      quan_books number(3),
      avail_books number(3),
      stud_name varchar(15),
      dept varchar(5),
      issue_date date,
      ret_date date,
      extra_days number(3),
      ren_date date,
      fine_amt number(5,2));
Table created.
Query 02: Insert minimum 5 records in the library table:
SQL> insert into library values(&book_no,'&book_title','&book_auth',
      &quan_books,&avail_books,
      &stud_name','&dept','&issue_date','&ret_date,
      &extra_days,'&re n_date',&fine_amt);
      Enter value for book_no: 101
      Enter value for book_title: OOPS Programing
      Enter value for book_auth: Balaguruswami
      Enter value for quan_books: 85
      Enter value for avail_books: 84
      Enter value for stud_name: Salil
      Enter value for dept: CSE
      Enter value for issue_date: 03-aug-2008
      Enter value for ret_date: 02-sep-2008
      Enter value for extra_days: 0
      Enter value for ren_date: 18-sep-2008
      Enter value for fine_amt: 0
old 1: insert into library
      values(&book_no,'&book_title','&book_auth',&quan_books,&avail_ books,'
new 1: insert into library values(101,'OOPS Programing','Balaguruswami',85,84,'Salil
      Dixit','CSE');
1 row created.
Query 03: Display all records:
SQL> select * from library;
Query 04: Find out total books in library:
SQL> select sum(quan_books) as "Total books in library" from library;
Total books in library
296
Query 05: Find out total quantity of books on DBMS
SQL> select sum(quan_books) as "Total books on DBMS" from library where
book_title='rdbms';
Total books on DBMS
70
Query 06: Calculate number of days taken
SQL> update library set days_taken=ret_date-issue_date;
5 rows updated.
Query 07: Calculate the return date
SQL> update library set ret_date=issue_date+30;
5 rows updated.
Query 08: Calculate the renewal date
SQL> update library set ren_date=ret_date+15;
5 rows updated.
Query 09: Find out who has taken C Prog book
SQL> select stud_name from library where book_title='C Prog';
                                      STUD_NAME
                                          Suraj
Query 10: Find out whether author “Balaguruswami” book is
available
SQL> select book_title,book_auth from library where book_auth='Balaguruswami' and
avail_books>0;
Query 11: Calculate the fine amount
SQL> update library set extra_days=days_taken-15;
5 rows updated.
SQL> update library set fine_amt=extra_days*0.50;
5 rows updated.
            STUDENT MARKSHEET PROCESSING
Query 01: Create a student_marksheet table
SQL> create table student_marksheet(
      sno number(3),
      regno varchar2(7),
      sname varchar2(20),
      mark1 number(3),
      mark2 number(3),
      mark3 number(3),
      total number(3),
      average number (5,2)); Table created.
Query 02: Insert minimum 5 records in the student_marksheet table
SQL> insert into student_marksheet
      values(&sno,'®no','&sname',&mark1,&mark2,&mark3,&total,&ave rage);
      Enter value for sno: 1
      Enter value for regno: U06CS093
      Enter value for sname: Sathya pradeep.p Enter value for mark1: 88
      Enter value for mark2: 89
      Enter value for mark3: 99
      Enter value for total: 0
      Enter value for average: 0
old 1: insert into student_marksheet
      values(&sno,'®no','&sname',&mark1,&mark2,&mark3,&total,&av
new 1: insert into student_marksheet values(1,'U06CS093','Sathya pradeep.p',88,89,99,0,0)
1 row created.
Query 03: Display all the records in the student_marksheet table
SQL> select * from student_marksheet;
Query 04: Calculate the total marks of each student
SQL> update student_marksheet set total=mark1+mark2+mark3;
5 rows updated.
Query 05: Calculate the average marks of each student
SQL> update student_marksheet set average=total/3; 5 rows updated.
Query 06: Calculate the sum of DBMS marks
SQL> select sum(DBMS) from student_marksheet;
                                        SUM(DBMS)
                                           439
Query 07: Find the total number of students
SQL> select count(sno) from student_marksheet;
                                    COUNT(SNO)
                                            5
Query 08: Find who has got maximum marks in DBMS
SQL> select sname,dbms from student_marksheet where dbms in(select max(dbms) from
student_marksheet);
                                    SNAME DBMS
                                       Vinod 98
Query 09: Find who has got minimum marks in OS
SQL> select sname,os from student_marksheet where os in(select min(os) from
student_marksheet);
                                      SNAME OS
                                     Ravindar 88
                                     Ram.R.V 80
Query 10: Find who has got the highest average in the class
SQL> select sname,average from student_marksheet where average in(select max(average)
from student_marksheet);
                                   SNAME AVERAGE
                                       Vinod 94
Query 11: Find the overall percentage
SQL> select (4/5)*100 as "Percentage" from dual;
                                        Percentage
                                              80
Query 12: Display all the updated records
SQL> select * from student_marksheet;
SNO   REGNO        SNAME       DBMS      DSP       OS   TOTAL   AVERAGE
1     U06CS093     Sathya       88       89        88   276       92
2     U06CS079     Ravindar     79       89        88   256      85.33
3     U06CS092     Satish       89       88        95   272      90.67
4     U06CS502     Vinod        98       89        95   282       94
5     U06CS082     Ram.R.V      85       78        88   251      83.67
              EMPLOYEE PAYROLL PROCESSING
Query 01: Create a employee table
SQL> create table employee(
       empno number(5),
       empname varchar2(30),
       dept varchar2(20));
Table created.
Query 02: Insert minimum 5 records in the employee table
SQL> insert into employee values(&empno,'&empname','&dept');
       Enter value for empno: 101
       Enter value for empname: Salil Dixit Enter value for dept: DataBase
old 1: insert into employee values(&empno,'&empname','&dept')
new 1: insert into employee values(101,'Sathya pradeep.p','DataBase')
1 row created.
Query 03: Display all the records in employee table
EMPNO            EMPNAME               DEPT
 101         Sathya pradeep.P        DataBase
 102              Ravindar          System Analysis
 103              Vinoth        Software Development
 104               Siva         Software Development
 105              Ram.r.v        Human Resources
 106             Raj kumar            Hardware
Query 04: Create a payment table
SQL> create table payment(
      empno number(5),
      empname varchar2(20),
      dept varchar2(20),
      basic number(8,2),
      hra number(7,2),
      cca number(7,2),
      da number(7,2),
      gross_sal number(8,2),
      pf number(7,2),
      annual_income number(15,2),
      pf number(7,2),
      annual_income number(15,2),
      net_sal number(9,2));
Table created.
Query 05: Insert minimum 5 records in the payment table
SQL> insert into payment values(&empno,'&design',&basic,&hra,&cca, &da,&gross_sal,
&pf, &annual_income,&tax,&net_sal);
      Enter value for empno: 101
      Enter value for design: DBA
      Enter value for basic: 27580
      Enter value for hra: 0
      Enter value for cca: 0
      Enter value for da: 0
      Enter value for gross_sal: 0
      Enter value for pf: 0
      Enter value for annual_income: 0
      Enter value for tax: 0
      Enter value for net_sal: 0
old 1: insert into payment
      values(&empno,'&design',&basic,&cca,&da,&gross_sal,&pf,&a nnual
new 1: insert into payment values(101,'DBA',27580,0,0,0,0,0,0,0)
1 row created.
Query 06: Display all records
EMPNO    DESIGN     BASICHRA   CCA   DA GROSS   PF   ANNUAL_INCOME   TAX   NET_SAL
101       DBA        27580     0     0    0     0         0          0       0
102     Analyst      25900     0     0   0      0          0         0       0
103     Developer    20985     0     0   0      0         0          0        0
104     Developer    23450     0     0   0      0          0         0        0
105     Manager      25689     0     0   0      0         0          0       0
106     Developer    22568     0     0   0      0         0          0        0
Query 07: Calculate HRA amount (15% of BASIC)
SQL> update payment set hra=basic*(15/100);
6 rows updated.
Query 08: Calculate CCA amount (15% of BASIC)
SQL> update payment set cca=basic*(15/100);
6 rows updated.
Query 09: Calculate DA amount (30% of BASIC)
SQL> update payment set da=basic*(30/100);
6 rows updated.
Query 10: Calculate gross salary
SQL> update payment set gross=basic+hra+cca+da;
6 rows updated.
Query 11: Calculate PF amount (12% of BASIC)
SQL> update payment set pf=basic*(12/100);
6 rows updated.
Query 12: Calculate ANNUAL_INCOME
SQL> update payment set annual_income=gross*12;
6 rows updated.
Query 13: Calculate TAX with following condition
More than: 1 Lakh 10% of BASIC
     2 Lakh 20% of BASIC
     3 Lakh 30% of BASIC
SQL> update payment set tax=annual_income*(10/100) where annual_income>=100000
and annual_income<200000;
0 rows updated.
SQL> update payment set tax=annual_income*(20/100) where annual_income>=200000
and annual_income<300000;
0 rows updated.
SQL> update payment set tax=annual_income*(30/100) where annual_income>300000;
6 rows updated.
Query 14: Calculate NET_SAL
SQL> update payment set net_sal=gross_sal-pf-tax;
6 rows updated.
Query 15: Display empno,dept and net_sal
SQL> select employee.empno,employee.dept,payment.net_sal from employee,payment
where employee.empno=payment.empno;
                     EMPNO              DEPT          NET_SAL
                       101            DataBase        27580
                       102          System Analysis   25900
                       103       Software Development 20985
                       104       Software Development 23450
                       105          Human Resources   25689
                       106           Hardware         22568
6 rows selected.