Presentation is loading. Please wait.

Presentation is loading. Please wait.

Database Programming Using Oracle 11g

Similar presentations


Presentation on theme: "Database Programming Using Oracle 11g"— Presentation transcript:

1 Database Programming Using Oracle 11g
Conditional Control-1

2 Conditional Control-1 IF-Then Statement

3 Conditional Control-1 Online Help Material:

4 Conditional Control-1 IF- Then Statement
It is used to executed statement when condition is true. It is independent construct One End if per if condition

5 Conditional Control-1 begin If condition then Statement -1;
End if; End;

6 Conditional Control-1 Implementing IF- Then Statement - I

7 Conditional Control-1 Write a PL/SQL block to insert a row in emp table if total number of employees in department # 20 are more less than 50 because as policy maximum number of employees can be 50 in any department Solution: Not Possible with SQL only. Need for control structure

8 Conditional Control-1 declare total number(10):=0;
max_id number(10):=0; begin select count(*) into total from emp where deptno=20; select max (empno) into max_id from emp; dbms_output.put_line('Table is not empty'); insert into emp(empno, deptno) values (max_id+1,20); dbms_output.put_line('Row is inserted in Department - 20'); end if; end;

9 Conditional Control-1 if total <=50 then
dbms_output.put_line('Table is not empty'); insert into emp(empno, deptno, ename) values (max_id+1,20, ‘Asim’); dbms_output.put_line('Row is inserted in Department - 20'); end if; end;

10 Conditional Control-1 Implementing IF- Then Statement-II

11 Conditional Control-1 Write a PL/SQL block to update the salary of all the employees if there are atleast 15 employees in the company and out of at least 5 have been attached with organization for more than 5 years then raise the salary of all the employee by 10% .

12 Conditional Control-1 declare total_emp number(10):=0;
total number(10):=0; percentage real(10):=0.10; begin select count(months_between (sysdate, hiredate)) into total_emp from emp where months_between (sysdate, hiredate)>=60; -- return total number of employees in the company select count(*) into total from emp; if total_emp > 5 and total > 15 then dbms_output.put_line('In the If Condition'); update emp set sal = sal + sal*percentage ; dbms_output.put_line('Increment given to all the employees'); end if; end; dbms_output.put_line('Table is not empty'); insert into emp(empno, deptno) values (max_id+1,20); dbms_output.put_line('Row is inserted in Department - 20');

13 Conditional Control-1 select count(months_between (sysdate, hiredate)) into total_emp from emp where months_between (sysdate, hiredate)>=60; select count(*) into total from emp; if total_emp > 5 and total > 15 then update emp set sal = sal + sal*percentage ; dbms_output.put_line('Increment given’ ); end if;end;

14 Conditional Control-1 IF- Then- else Statement
It is used to executed statement when condition is true. If condition is not true then there is an alternate path available One closing end if;

15 Conditional Control-1 begin If condition then Statement -1;
Else Statement-1; End if; End;

16 Conditional Control-1 Implementing IF- Then-else Statement-I

17 Conditional Control-1 Write a PL/SQL block to check whether you are logged in as ‘APEX_PUBLIC_USER’ and if this is true then display success message and then check whether maximum salary has been achieved against designation of ANALYST or not. As company policy maximum salary which can be paid to Analyst is not more than 5000 otherwise display message not achieved.

18 Conditional Control-1 declare max_sal number(10):=0;
designation varchar2(30):='ANALYST'; begin select max(sal) into max_sal from emp where job=designation; if user = 'APEX_PUBLIC_USER' and max_sal <=5000 then

19 Conditional Control-1 dbms_output.put_line ('Current Maximum Salary for ' || designation || ' is : ' || max_sal); dbms_output.put_line ('Maximum Salary not achieved'); else dbms_output.put_line ('Maximum achieved'); end if; end;

20 Conditional Control-1 Implementing IF- Then-else Statement-II

21 Conditional Control-1 Write a PL/SQL block to proceed as follow of emp = 7369: i. Salary > 3000 and less than 6000 and designation = ‘MANAGER’ Message: Senior Management ii. Not part of Management

22 Conditional Control-1 declare designation emp.job%type;
salary emp.sal%type; begin select job , sal into designation, salary from emp where empno=7369; if designation =‘ANALYST' and salary > 3000 and salary < 6000 then

23 Conditional Control-1 dbms_output.put_line(‘Senior Management'); else
dbms_output.put_line(‘Not Part of Management'); end if; end;

24 Conditional Control-1 ELSIF Statement It can be used with IF only
Dependent construct One closing end if;

25 Conditional Control-1 begin If condition then Statement -1;
Elsif condition then Statement-1; End if; -- Only one End if per if End;

26 Conditional Control-1 Implementing IF- Then-elsif Statement-I

27 Conditional Control-1 Write a PL/SQL block to proceed as follow of emp = 7369: i. Salary > 3000 and less than 6000 and designation = ‘MANAGER’ Message: Senior Management ii. Salary > 6000 and less than 9000 designation = ‘PRESIDENT’ Message: Executive Management iii. Not eligible

28 Conditional Control-1 declare designation emp.job%type;
salary emp.sal%type; begin select job , sal into designation, salary from emp where empno=7369; if designation =‘PRESIDENT' and salary > 6000 and salary < 9000 then

29 Conditional Control-1 dbms_output.put_line('Executive Management');
elsif designation='MANAGER' and salary > 3000 and salary < 6000 then dbms_output.put_line('Senior Management'); else dbms_output.put_line('Not part of Management'); end if; end;

30 Conditional Control-1 Implementing IF- Then-elsif Statement-II

31 Conditional Control-1 Write a PL/SQL block to proceed display for any given date: If day is Saturday or Sunday then display ‘ Weekend’ If day is Monday or Tuesday then display ‘ Start of week’ If Day is Wednesay or Friday then display ‘ Toward end of week’

32 Conditional Control-1 DECLARE
v_date DATE := TO_DATE('18-Dec-2013', 'DD-MON-YYYY'); v_day VARCHAR2(15); BEGIN v_day := RTRIM(TO_CHAR(v_date, 'DAY')); DBMS_OUTPUT.PUT_LINE ('Day of the Date: ' || ' 18-Dec-2012 is : ' || v_day);

33 Conditional Control-1 IF v_day IN ('SATURDAY', 'SUNDAY') THEN
DBMS_OUTPUT.PUT_LINE (v_date||' falls on weekend'); ELSif v_day in ('MONDAY', ' TUESDAY') then DBMS_OUTPUT.PUT_LINE (v_date||' falls on start of week'); ELSif v_day in ('WEDNESDAY', ' FRIDAY') then

34 Conditional Control-1 DBMS_OUTPUT.PUT_LINE (v_date||' falls toward mid week'); END IF; DBMS_OUTPUT.PUT_LINE('Done...'); END;

35 Conditional Control-1 Nested IF Parent and child if conditions
Child if will be executed if parent is true. One end if per if keyword

36 Conditional Control-1 Implementing Nested-IF -I

37 Conditional Control-1 DECLARE a number(3) := 100; b number(3) := 200;
BEGIN IF( a between 0 and 100 ) THEN IF( b between 101 and 200 ) THEN dbms_output.put_line('Value of a is 100 and b is 200' );

38 Conditional Control-1 END IF;
dbms_output.put_line('Exact value of a is : ' || a ); dbms_output.put_line('Exact value of b is : ' || b ); END;

39 Conditional Control-1 Questions to Practice:
Write at least 3 different version of questions solution discussed. i. Write a PL/SQL block to check whether number of employess in Emp table are odd or even, if number of employees are odd then display message ‘ Odd number of employees else display ‘ Even number of employees’


Download ppt "Database Programming Using Oracle 11g"

Similar presentations


Ads by Google