Problem #1:
SQL> select * from dept;

   DEPTNO DNAME          LOC
--------- -------------- -------------
       10 ACCOUNTING     NEW YORK
       20 RESEARCH       DALLAS
       30 SALES          CHICAGO
       40 OPERATIONS     BOSTON
Explain the code below including an explanation of what would happen if the user entered 20 and what would happen if the user entered 24.
SET SERVEROUTPUT ON
SET VERIFY OFF
  ACCEPT p_deptno PROMPT 'Enter the dept no ';
DECLARE 
  v_deptno      dept.deptno%TYPE := &p_deptno; 
  v_dname       dept.dname%TYPE;
  v_loc         dept.loc%TYPE;  
BEGIN
  SELECT dname, loc
     INTO v_dname, v_loc
     FROM dept
     WHERE deptno = v_deptno;
EXCEPTION
  WHEN NO_DATA_FOUND THEN
     dbms_output.put_line('Invalid Department ' || TO_CHAR(v_deptno));
END;
/
SET SERVEROUTPUT OFF
SET VERIFY ON


Problem #2:
CREATE OR REPLACE TRIGGER sal_check
   BEFORE UPDATE OF sal ON emp_copy
   FOR EACH ROW
   WHEN (new.sal < old.sal)
BEGIN
   RAISE_APPLICATION_ERROR(-20002,'Salary reduction');
END sal_check;
/
SQL> update emp_copy
  2  set sal = 2000
  3  where empno = 7788;

SQL> update emp_copy 
  2  set sal = 4000
  3  where empno = 7788;
Explain the results of the two updates shown above.

Problem #3:
SET VERIFY OFF
DECLARE

  v_idno       copy_donation.idno%TYPE;
  v_driveno    copy_donation.driveno%TYPE;
  v_contamt    copy_donation.contamt%TYPE;
  v_newcontamt copy_donation.contamt%TYPE;
  v_code       VARCHAR2(2);
  CURSOR donor_cursor IS
    SELECT idno, driveno, contamt
       FROM copy_donation;
  FUNCTION CalcNewDon
    (f_code   VARCHAR2, f_contamt NUMBER)
    RETURN NUMBER IS
      f_newcontamt  quiz_donation.contamt%TYPE;
    BEGIN
      IF f_code = 'AA' THEN
         f_newcontamt := f_contamt * 1.3;
      ELSE
         IF f_code = 'BB' THEN
            f_newcontamt := f_contamt * 1.2;
         ELSE
            IF f_code = 'CC' THEN
               f_newcontamt := f_contamt * 1.1;
            ELSE
               f_newcontamt := f_contamt;
            END IF;
         END IF;
       END IF;
       RETURN f_newcontamt;
   END CalcNewDon;  
 
  PROCEDURE AddDonProc 
    (p_idno        quiz_donation.idno%TYPE,
     p_driveno     quiz_donation.driveno%TYPE,
     p_contamt     quiz_donation.contamt%TYPE) AS
  BEGIN
     INSERT INTO quiz_donation
        VALUES(p_idno, p_driveno, sysdate, p_contamt);
  END AddDonProc;

    

BEGIN
  OPEN donor_cursor;
  FETCH donor_cursor INTO v_idno, v_driveno, v_contamt;
  WHILE donor_cursor%FOUND LOOP
   IF v_contamt > 500 THEN
     v_code := 'AA';
     v_newcontamt := CalcNewDon(v_code, v_contamt);
   ELSE
     IF v_contamt > 200 THEN
        v_code := 'BB';
        v_newcontamt := CalcNewDon(v_code, v_contamt);  
     ELSE
       IF v_contamt > 75 THEN
          v_code := 'CC';
          v_newcontamt := CalcNewDon(v_code, v_contamt);
       ELSE
          v_code := 'DD';
          v_newcontamt := CalcNewDon(v_code, v_contamt);
       END IF;
     END IF;
   END IF;
   AddDonProc (v_idno, v_driveno, v_newcontamt);
   FETCH donor_cursor INTO v_idno, v_driveno, v_contamt;
  END LOOP;
  CLOSE donor_cursor;
END;
/
SET VERIFY ON
Here is a copy of copy_donation.
SQL> select * from copy_donation;

IDNO  DRI CONTDATE    CONTAMT
----- --- --------- ---------
11111 100 07-JAN-99        25
12121 200 23-FEB-99        40
23456 100 03-MAR-99        20
33333 300 10-MAR-99        10
22222 100 14-MAR-99        10
12121 100 04-JUN-99        50
23456 300 14-JUN-99        10
11111 200 12-JUN-99        35

8 rows selected.
And here is the layout of quiz_donation.
SQL> desc quiz_donation;
 Name                            Null?    Type
 ------------------------------- -------- ----
 IDNO                                     VARCHAR2(5)
 DRIVENO                                  VARCHAR2(3)
 CONTDATE                                 DATE
 CONTAMT                                  NUMBER(6,2)

Show the output that would be produced from the code above. Explain the processing very completely.

Problem #4: Look at the notes on exceptions. You can do this problem by modifying existing programs or creating new ones. Use the three kinds of exceptions in a PL/SQL program or programs(s). Document, explain and show results.

In problem #5 #6, and #7, make sure you have one external function, one internal function, one external procedure and one internal procedure.

Problem #5: Modify one of the cursor programs you did and put some of the code in a procedure that you call.

Problem #6: Modify one of the cursor programs you did and put some of the code in a function that you call.

Problem #7: Modify one of the cursor programs you did and put some of the code in a procedure that you call and some in a function that you call. Note you can also use one of my cursor programs that I did not change to have procedures or functions.

Problem #8: Set up a trigger so that when you run one of your cursor programs, you fire your trigger. Run the program and demonstrate that it caused the trigger to fire.

Problem #9: Do something with cursors, tables and records. Note I am talking about tables and records as used in the handout Record and Table types and the examples I went over in class.