Académique Documents
Professionnel Documents
Culture Documents
D17169GC21
Edition 2.1
December 2006
D48232
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Authors Copyright © 2006, Oracle. All rights reserved.
Graphic Designer
Satish Bettegowda
Editors
Nita Pavitran
Richard Wallis
Publisher
Sheryl Domingue
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Contents
Preface
I Introduction
Lesson Objectives I-2
iii
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Syntax for Passing Parameters 1-14
Parameter Passing: Examples 1-15
Using the DEFAULT Option for Parameters 1-16
Summary of Parameter Modes 1-18
Invoking Procedures 1-19
Handled Exceptions 1-20
Handled Exceptions: Example 1-21
Exceptions Not Handled 1-22
Exceptions Not Handled: Example 1-23
iv
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
3 Creating Packages
Objectives 3-2
PL/SQL Packages: Overview 3-3
Components of a PL/SQL Package 3-4
Visibility of Package Components 3-5
Developing PL/SQL Packages 3-6
Creating the Package Specification 3-7
Example of Package Specification: comm_pkg 3-8
Creating the Package Body 3-9
v
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
5 Using Oracle-Supplied Packages in Application Development
Objectives 5-2
Using Oracle-Supplied Packages 5-3
List of Some Oracle-Supplied Packages 5-4
How the DBMS_OUTPUT Package Works 5-5
Interacting with Operating System Files 5-6
File Processing Using the UTL_FILE Package 5-7
Exceptions in the UTL_FILE Package 5-8
FOPEN and IS_OPEN Function Parameters 5-9
vi
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Declaring Cursor Variables 6-11
Dynamically Executing a PL/SQL Block 6-12
Using Native Dynamic SQL to Compile PL/SQL Code 6-13
Using the DBMS_SQL Package 6-14
Using DBMS_SQL with a DML Statement 6-15
Using DBMS_SQL with a Parameterized DML Statement 6-16
Comparison of Native Dynamic SQL and the DBMS_SQL Package 6-17
DBMS_METADATA Package 6-18
Metadata API 6-19
vii
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Using the NOCOPY Hint 7-21
Effects of the NOCOPY Hint 7-22
NOCOPY Hint Can Be Ignored 7-23
PARALLEL_ENABLE Hint 7-24
Summary 7-25
Practice 7: Overview 7-26
8 Managing Dependencies
Objectives 8-2
viii
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
9 Manipulating Large Objects
Objectives 9-2
What Is a LOB? 9-3
Contrasting LONG and LOB Data Types 9-5
Anatomy of a LOB 9-6
Internal LOBs 9-7
Managing Internal LOBs 9-8
What Are BFILEs? 9-9
Securing BFILEs 9-10
10 Creating Triggers
Objectives 10-2
Types of Triggers 10-3
Guidelines for Designing Triggers 10-4
Creating DML Triggers 10-5
Types of DML Triggers 10-6
Trigger Timing 10-7
Trigger-Firing Sequence 10-8
ix
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Trigger Event Types and Body 10-10
Creating a DML Statement Trigger 10-11
Testing SECURE_EMP 10-12
Using Conditional Predicates 10-13
Creating a DML Row Trigger 10-14
Using OLD and NEW Qualifiers 10-15
Using OLD and NEW Qualifiers: Example Using AUDIT_EMP 10-16
Restricting a Row Trigger: Example 10-17
Summary of the Trigger Execution Model 10-18
x
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
12 Understanding and Influencing the PL/SQL Compiler
Objectives 12-2
Native and Interpreted Compilation 12-3
Features and Benefits of Native Compilation 12-4
Considerations When Using Native Compilation 12-5
Parameters Influencing Compilation 12-6
Switching Between Native and Interpreted Compilation 12-7
Viewing Compilation Information in the Data Dictionary 12-8
Using Native Compilation 12-9
Additional Practices
Additional Practice: Solutions
Additional Practices: Table Descriptions and Data
xi
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Oracle University and SQL Star International Limited use onlyฺ
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Preface
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Oracle University and SQL Star International Limited use onlyฺ
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Profile
Preface-3
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Related Publications
Oracle Publications
Title Part Number
Oracle Database Application Developer’s Guide – Fundamentals B10795-01
(10g Release 1)
Oracle Database Application Developer’s Guide – Large Objects B10796-01
(10g Release 1)
PL/SQL Packages and Types Reference (10g Release 1) B10802-01
Additional Publications
• System release bulletins
• Installation and user’s guides
• Read-me files
• International Oracle Users Group (IOUG) articles
• Oracle Magazine
Preface-4
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Typographic Conventions
Bold italic Glossary terms (if there is a The algorithm inserts the new key.
glossary)
Preface-5
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Typographic Conventions (continued)
Quotation Lesson and chapter This subject is covered in Unit II, Lesson 3, “Working
marks titles in cross with Objects.”
references, interface
elements with long Select the “Include a reusable module component” and
names that have click Finish.
only initial caps
Use the “WHERE clause of query” property.
Preface-6
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Typographic Conventions (continued)
Preface-7
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Oracle University and SQL Star International Limited use onlyฺ
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Additional
Practices
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Additional Practices: Overview
These additional practices are provided as a supplement to the course Oracle Database 10g:
Develop PL/SQL Program Units. In these practices, you apply the concepts that you learned
in the course.
The additional practices comprise two parts:
Part A provides supplemental exercises to create stored procedures, functions, packages, and
triggers, and to use the Oracle-supplied packages with iSQL*Plus as the development
environment. The tables used in this portion of the additional practice include EMPLOYEES,
JOBS, JOB_HISTORY, and DEPARTMENTS.
Part B is a case study that can be completed at the end of the course. This part supplements
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle Database 10g: Develop PL/SQL Program Units AP-2
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part A
Entity Relationship Diagram
Human Resources:
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle Database 10g: Develop PL/SQL Program Units AP-3
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part A (continued)
Note: These exercises can be used for extra practice when discussing how to create
procedures.
1. In this exercise, create a program to add a new job into the JOBS table.
a. Create a stored procedure called NEW_JOB to enter a new order into the JOBS
table. The procedure should accept three parameters. The first and second
parameters supply a job ID and a job title. The third parameter supplies the
minimum salary. Use the maximum salary for the new job as twice the minimum
salary supplied for the job ID.
b. Invoke the procedure to add a new job with job ID 'SY_ANAL', job title
'System Analyst', and minimum salary of 6000.
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle Database 10g: Develop PL/SQL Program Units AP-7
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B
Entity Relationship Diagram
TITLE
for #* ID
RESERVATION * title
#* reservation date the subject * description
of o rating
set up for o category
available as
a copy
TITLE_COPY
#* ID
* status
the subject of
responsible
for
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle Database 10g: Develop PL/SQL Program Units AP-8
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B (continued)
In this case study, you create a package named VIDEO_PKG that contains procedures and
functions for a video store application. This application enables customers to become a
member of the video store. Any member can rent movies, return rented movies, and reserve
movies. Additionally, you create a trigger to ensure that any data in the video tables is
modified only during business hours.
Create the package by using iSQL*Plus and use the DBMS_OUTPUT Oracle-supplied
package to display messages.
The video store database contains the following tables: TITLE, TITLE_COPY, RENTAL,
RESERVATION, and MEMBER. The entity relationship diagram is shown on the previous
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle Database 10g: Develop PL/SQL Program Units AP-9
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B (continued)
1. Load and execute the E:\labs\PLPU\labs\buildvid1.sql script to create all
the required tables and sequences that are needed for this exercise.
2. Load and execute the E:\labs\PLPU\labs\buildvid2.sql script to populate
all the tables created through the buildvid1.sql script.
3. Create a package named VIDEO_PKG with the following procedures and functions:
a. NEW_MEMBER: A public procedure that adds a new member to the MEMBER
table. For the member ID number, use the sequence MEMBER_ID_SEQ; for the
join date, use SYSDATE. Pass all other values to be inserted into a new row as
parameters.
b. NEW_RENTAL: An overloaded public function to record a new rental. Pass the
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle Database 10g: Develop PL/SQL Program Units AP-10
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B (continued)
4. Use the following scripts located in the E:\labs\PLPU\soln directory to test your
routines:
a. Add two members using sol_apb_04_a_new_members.sql.
b. Add new video rentals using sol_apb_04_b_new_rentals.sql.
c. Return movies using the sol_apb_04_c_return_movie.sql script.
5. The business hours for the video store are 8:00 a.m. to 10:00 p.m., Sunday through
Friday, and 8:00 a.m. to 12:00 a.m. on Saturday. To ensure that the tables can be
modified only during these hours, create a stored procedure that is called by triggers on
the tables.
a. Create a stored procedure called TIME_CHECK that checks the current time
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle Database 10g: Develop PL/SQL Program Units AP-11
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Oracle University and SQL Star International Limited use onlyฺ
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
_________
Additional
Practice:
Solutions
_________
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part A: Additional Practice 1 Solutions
1. In this exercise, create a program to add a new job into the JOBS table.
a. Create a stored procedure called NEW_JOB to enter a new order into the JOBS table.
The procedure should accept three parameters. The first and second parameters supply a
job ID and a job title. The third parameter supplies the minimum salary. Use the
maximum salary for the new job as twice the minimum salary supplied for the job ID.
CREATE OR REPLACE PROCEDURE new_job(
jobid IN jobs.job_id%TYPE,
Procedure created.
No errors.
b. Invoke the procedure to add a new job with job ID 'SY_ANAL', job title
'System Analyst', and minimum salary 6,000.
SET SERVEROUTPUT ON
EXECUTE new_job ('SY_ANAL', 'System Analyst', 6000)
c. Verify that a row was added, and note the new job ID for use in the next exercise.
Commit the changes.
SELECT *
FROM jobs
WHERE job_id = 'SY_ANAL';
COMMIT;
Commit complete.
2. In this exercise, create a program to add a new row to the JOB_HISTORY table for an
existing employee.
a. Create a stored procedure called ADD_JOB_HIST to add a new row into the
JOB_HISTORY table for an employee who is changing his job to the new job ID
('SY_ANAL') that you created in exercise1b.
The procedure should provide two parameters: one for the employee ID who is changing
the job, and the second for the new job ID. Read the employee ID from the EMPLOYEES
Change the hire date of this employee in the EMPLOYEES table to today’s date. Update
the job ID of this employee to the job ID passed as parameter (use the 'SY_ANAL' job
ID) and salary equal to the minimum salary for that job ID plus 500.
Procedure created.
No errors.
b. Disable all triggers on the EMPLOYEES, JOBS, and JOB_HISTORY tables before
invoking the ADD_JOB_HIST procedure.
ALTER TABLE employees DISABLE ALL TRIGGERS;
ALTER TABLE jobs DISABLE ALL TRIGGERS;
ALTER TABLE job_history DISABLE ALL TRIGGERS;
Table altered.
Table altered.
c. Execute the procedure with employee ID 106 and job ID 'SY_ANAL' as parameters.
EXECUTE add_job_hist(106, 'SY_ANAL')
d. Query the JOB_HISTORY and EMPLOYEES tables to view your changes for employee
106, and then commit the changes.
SELECT * FROM job_history
WHERE employee_id = 106;
COMMIT;
Commit complete.
Table altered.
Table altered.
Table altered.
3. In this exercise, create a program to update the minimum and maximum salaries for a job in
the JOBS table.
a. Create a stored procedure called UPD_JOBSAL to update the minimum and maximum
salaries for a specific job ID in the JOBS table. The procedure should provide three
parameters: the job ID, a new minimum salary, and a new maximum salary. Add
exception handling to account for an invalid job ID in the JOBS table. Raise an exception
if the maximum salary supplied is less than the minimum salary. Provide a message that
will be displayed if the row in the JOBS table is locked.
Procedure created.
No errors.
Table altered.
Table altered.
e. Query the JOBS table to view your changes, and then commit the changes.
SELECT *
FROM jobs
WHERE job_id = 'SY_ANAL';
Table altered.
Table altered.
4. In this exercise, create a procedure to monitor whether employees have exceeded their
average salaries for their job type.
Trigger altered.
Table altered.
c. Write a stored procedure called CHECK_AVGSAL that checks whether each employee’s
salary exceeds the average salary for the JOB_ID. The average salary for a job is
calculated from information in the JOBS table. If the employee’s salary exceeds the
average for his or her job, then update his or her EXCEED_AVGSAL column in the
EMPLOYEES table to a value of YES; otherwise, set the value to NO. Use a cursor to
select the employee’s rows using the FOR UPDATE option in the query. Add exception
handling to account for a record being locked.
Hint: The resource locked/busy error number is –54. Write and use a local function
called GET_JOB_AVGSAL to determine the average salary for a job ID specified as a
parameter.
CREATE OR REPLACE PROCEDURE check_avgsal IS
avgsal_exceeded employees.exceed_avgsal%type;
CURSOR emp_csr IS
SELECT employee_id, job_id, salary
FROM employees
FOR UPDATE;
e_resource_busy EXCEPTION;
PRAGMA EXCEPTION_INIT(e_resource_busy, -54);
BEGIN
Procedure created.
No errors.
d. Execute the CHECK_AVGSAL procedure. Then, to view the results of your modifications,
write a query to display the employee’s ID, job, the average salary for the job, the
employee’s salary, and the exceed_avgsal indicator column for employees whose
salaries exceed the average for their job, and finally commit the changes.
EXECUTE check_avgsal
COMMIT;
31 rows selected.
Commit complete.
5. Create a subprogram to retrieve the number of years of service for a specific employee.
Function created.
No errors.
ERROR at line 1:
ORA-20348: Employee with ID 999 does not exist.
ORA-06512: at "ORA1.GET_YEARS_SERVICE", line 22
ORA-06512: at line 1
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-10
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part A: Additional Practice 5 Solutions (continued)
d. Query the JOB_HISTORY and EMPLOYEES tables for the specified employee to verify
that the modifications are accurate.
Note: The values represented in the results on this page may differ from those you get
when you run these queries.
SELECT employee_id, job_id,
MONTHS_BETWEEN(end_date, start_date)/12 duration
FROM job_history;
11 rows selected.
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-11
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part A: Additional Practice 6 Solutions
6. In this exercise, create a program to retrieve the number of different jobs that an employee
worked on during his or her service.
The function should accept the employee ID in a parameter, and return the number of
different jobs that the employee worked on until now, including the present job. Add
exception handling to account for an invalid employee ID.
Function created.
No errors.
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-12
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part A: Additional Practice 6 Solutions (continued)
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-13
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part A: Additional Practice 7 Solutions
7. Create a package called EMPJOB_PKG that contains your NEW_JOB, ADD_JOB_HIST, and
UPD_JOBSAL procedures, as well as your GET_YEARS_SERVICE and GET_JOB_COUNT
functions.
a. Create the package specification with all the subprogram constructs public. Move any
subprogram local-defined types into the package specification.
CREATE OR REPLACE PACKAGE empjob_pkg IS
TYPE jobs_tabtype IS TABLE OF jobs.job_id%type;
Package created.
No errors.
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-14
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part A: Additional Practice 7 Solutions (continued)
b. Create the package body with the subprogram implementation; remember to remove
(from the subprogram implementations) any types that you moved into the package
specification.
CREATE OR REPLACE PACKAGE BODY empjob_pkg IS
PROCEDURE add_job_hist(
emp_id IN employees.employee_id%TYPE,
new_jobid IN jobs.job_id%TYPE) IS
BEGIN
INSERT INTO job_history
FUNCTION get_job_count(
emp_id IN employees.employee_id%TYPE) RETURN NUMBER IS
jobtab jobs_tabtype;
CURSOR empjob_csr IS
SELECT job_id
FROM job_history
WHERE employee_id = emp_id
UNION
SELECT job_id
FROM employees
WHERE employee_id = emp_id;
BEGIN
OPEN empjob_csr;
FETCH empjob_csr BULK COLLECT INTO jobtab;
CLOSE empjob_csr;
RETURN jobtab.count;
EXCEPTION
WHEN NO_DATA_FOUND THEN
RAISE_APPLICATION_ERROR(-20348,
'Employee with ID '|| emp_id ||' does not exist!');
END get_job_count;
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-15
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part A: Additional Practice 7 Solutions (continued)
FUNCTION get_years_service(
emp_id IN employees.employee_id%TYPE) RETURN NUMBER IS
CURSOR jobh_csr IS
SELECT MONTHS_BETWEEN(end_date, start_date)/12 years_in_job
FROM job_history
WHERE employee_id = emp_id;
years_service NUMBER(2) := 0;
years_in_job NUMBER(2) := 0;
BEGIN
FOR jobh_rec IN jobh_csr
PROCEDURE new_job(
jobid IN jobs.job_id%TYPE,
title IN jobs.job_title%TYPE,
minsal IN jobs.min_salary%TYPE) IS
maxsal jobs.max_salary%TYPE := 2 * minsal;
BEGIN
INSERT INTO jobs(job_id, job_title, min_salary, max_salary)
VALUES (jobid, title, minsal, maxsal);
DBMS_OUTPUT.PUT_LINE ('New row added to JOBS table:');
DBMS_OUTPUT.PUT_LINE (jobid || ' ' || title ||' '||
minsal || ' ' || maxsal);
END new_job;
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-16
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part A: Additional Practice 7 Solutions (continued)
PROCEDURE upd_jobsal(
jobid IN jobs.job_id%type,
new_minsal IN jobs.min_salary%type,
new_maxsal IN jobs.max_salary%type) IS
dummy PLS_INTEGER;
e_resource_busy EXCEPTION;
sal_error EXCEPTION;
PRAGMA EXCEPTION_INIT (e_resource_busy , -54);
BEGIN
IF (new_maxsal < new_minsal) THEN
No errors.
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-17
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part A: Additional Practice 7 Solutions (continued)
Trigger altered.
e. Query the JOBS, JOB_HISTORY, and EMPLOYEES tables to verify the results.
SELECT * FROM jobs WHERE job_id = 'PR_MAN';
SELECT * FROM job_history WHERE employee_id = 110;
SELECT job_id, salary FROM employees WHERE employee_id = 110;
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-18
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part A: Additional Practice 8 Solutions
8. In this exercise, create a trigger to ensure that the minimum and maximum salaries of a job
are never modified such that the salary of an existing employee with that job ID is outside the
new range specified for the job.
a. Create a trigger called CHECK_SAL_RANGE that is fired before every row that is
updated in the MIN_SALARY and MAX_SALARY columns in the JOBS table. For any
minimum or maximum salary value that is changed, check whether the salary of any
existing employee with that job ID in the EMPLOYEES table falls within the new range of
salaries specified for this job ID. Include exception handling to cover a salary range
Trigger created.
No errors.
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-19
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part A: Additional Practice 8 Solutions (continued)
b. Test the trigger using the SY_ANAL job, setting the new minimum salary to 5000 and
the new maximum salary to 7000. Before you make the change, write a query to display
the current salary range for the SY_ANAL job ID, and another query to display the
employee ID, last name, and salary for the same job ID. After the update, query the
change (if any) to the JOBS table for the specified job ID.
SELECT * FROM jobs
WHERE job_id = 'SY_ANAL';
UPDATE jobs
SET min_salary = 5000, max_salary = 7000
WHERE job_id = 'SY_ANAL';
1 row updated.
c. Using the job SY_ANAL, set the new minimum salary to 7000 and the new maximum salary
to 18000. Explain the results.
UPDATE jobs
SET min_salary = 7000, max_salary = 18000
WHERE job_id = 'SY_ANAL';
UPDATE jobs
*
ERROR at line 1:
ORA-20550: Employees exist whose salary is out of the specified range.
Therefore the specified salary range cannot be updated.
ORA-06512: at "ORA1.CHECK_SAL_RANGE", line 14
ORA-04088: error during execution of trigger 'ORA1.CHECK_SAL_RANGE'
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-20
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part A: Additional Practice 8 Solutions (continued)
The update fails to change the salary range due to the functionality provided by the
CHECK_SAL_RANGE trigger because the employee 106 who has the SY_ANAL job
ID has a salary of 6500, which is less than the minimum salary for the new salary
range specified in the UPDATE statement.
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-21
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B: Entity Relationship Diagram
TITLE
for #* ID
RESERVATION * title
#* reservation date the subject * description
of o rating
set up o category
available as
TITLE_COP
Y
#* ID
the subject
responsible f
for
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-22
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B (continued)
In this case study, create a package named VIDEO_PKG that contains procedures and functions
for a video store application. This application enables customers to become a member of the
video store. Any member can rent movies, return rented movies, and reserve movies.
Additionally, create a trigger to ensure that any data in the video tables is modified only during
business hours.
Create the package by using iSQL*Plus and use the DBMS_OUTPUT Oracle-supplied package to
display messages.
The video store database contains the following tables: TITLE, TITLE_COPY, RENTAL,
RESERVATION, and MEMBER. The entity relationship diagram is shown on the previous page.
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-23
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B: Additional Practice 1 Solutions
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-24
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B: Additional Practice 1 Solutions (continued)
CREATE TABLE TITLE_COPY
(copy_id NUMBER(10)
, title_id NUMBER(10)
CONSTRAINT copy_title_id_fk
REFERENCES title(title_id)
, status VARCHAR2(15)
CONSTRAINT copy_status_nn NOT NULL
CONSTRAINT copy_status_ck CHECK (status IN ('AVAILABLE',
'DESTROYED',
'RENTED', 'RESERVED'))
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-25
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B: Additional Practice 2 Solutions
COMMIT;
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-26
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B: Additional Practice 2 Solutions (continued)
INSERT INTO TITLE (title_id, title, description, rating, category,
release_date)
VALUES (TITLE_ID_SEQ.NEXTVAL, 'Willie and Christmas Too',
'All of Willie''s friends made a Christmas list for Santa, but Willie
has yet to create his own wish list.', 'G', 'CHILD', '05-OCT-95');
INSERT INTO TITLE (title_id, title, description, rating, category,
release_date)
VALUES (TITLE_ID_SEQ.NEXTVAL, 'Alien Again', 'Another installment of
science fiction history. Can the heroine save the planet from the alien
life form?', 'R', 'SCIFI', '19-MAY-95');
COMMIT;
COMMIT;
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-27
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B: Additional Practice 2 Solutions (continued)
INSERT INTO reservation VALUES (sysdate-1, 101, 93);
INSERT INTO reservation VALUES (sysdate-2, 106, 102);
COMMIT;
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-28
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B: Additional Practice 3 Solutions
3. Create a package named VIDEO_PKG with the following procedures and functions:
a. NEW_MEMBER: A public procedure that adds a new member to the MEMBER table. For
the member ID number, use the sequence MEMBER_ID_SEQ. For the join date, use
SYSDATE. Pass all other values to be inserted into a new row as parameters.
b. NEW_RENTAL: An overloaded public function to record a new rental. Pass the title ID
number for the video that a customer wants to rent, and either the customer’s last name or
his or her member ID number into the function. The function should return the due date
d. RESERVE_MOVIE: A private procedure that executes only if all the video copies
requested in the NEW_RENTAL procedure have a status of RENTED. Pass the member ID
number and the title ID number to this procedure. Insert a new record into the
RESERVATION table and record the reservation date, member ID number, and title ID
number. Print a message indicating that a movie is reserved and its expected date of
return.
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-29
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B: Additional Practice 3 Solutions (continued)
FUNCTION new_rental
(membername IN member.last_name%TYPE,
titleid IN rental.title_id%TYPE)
RETURN DATE;
PROCEDURE return_movie
(titleid IN rental.title_id%TYPE,
copyid IN rental.copy_id%TYPE,
sts IN title_copy.status%TYPE);
END video_pkg;
/
SHOW ERRORS
Package created.
No errors.
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-30
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B: Additional Practice 3 Solutions (continued)
PROCEDURE reserve_movie
(memberid IN reservation.member_id%TYPE,
titleid IN reservation.title_id%TYPE) IS
CURSOR rented_csr IS
SELECT exp_ret_date
FROM rental
WHERE title_id = titleid
AND act_ret_date IS NULL;
BEGIN
INSERT INTO reservation (res_date, member_id, title_id)
PROCEDURE return_movie(
titleid IN rental.title_id%TYPE,
copyid IN rental.copy_id%TYPE,
sts IN title_copy.status%TYPE) IS
v_dummy VARCHAR2(1);
CURSOR res_csr IS
SELECT *
FROM reservation
WHERE title_id = titleid;
BEGIN
SELECT '' INTO v_dummy
FROM title
WHERE title_id = titleid;
UPDATE rental
SET act_ret_date = SYSDATE
WHERE title_id = titleid
AND copy_id = copyid AND act_ret_date IS NULL;
UPDATE title_copy
SET status = UPPER(sts)
WHERE title_id = titleid AND copy_id = copyid;
FOR res_rec IN res_csr LOOP
IF res_csr%FOUND THEN
DBMS_OUTPUT.PUT_LINE('Put this movie on hold -- '||
'reserved by member #' || res_rec.member_id);
END IF;
END LOOP;
EXCEPTION
WHEN OTHERS THEN
exception_handler(SQLCODE, 'RETURN_MOVIE');
END return_movie;
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-31
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B: Additional Practice 3 Solutions (continued)
FUNCTION new_rental(
memberid IN rental.member_id%TYPE,
titleid IN rental.title_id%TYPE) RETURN DATE IS
CURSOR copy_csr IS
SELECT * FROM title_copy
WHERE title_id = titleid
FOR UPDATE;
flag BOOLEAN := FALSE;
BEGIN
FUNCTION new_rental(
membername IN member.last_name%TYPE,
titleid IN rental.title_id%TYPE) RETURN DATE IS
CURSOR copy_csr IS
SELECT * FROM title_copy
WHERE title_id = titleid
FOR UPDATE;
flag BOOLEAN := FALSE;
memberid member.member_id%TYPE;
CURSOR member_csr IS
SELECT member_id, last_name, first_name
FROM member
WHERE LOWER(last_name) = LOWER(membername)
ORDER BY last_name, first_name;
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-32
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B: Additional Practice 3 Solutions (continued)
BEGIN
SELECT member_id INTO memberid
FROM member
WHERE lower(last_name) = lower(membername);
FOR copy_rec IN copy_csr LOOP
IF copy_rec.status = 'AVAILABLE' THEN
UPDATE title_copy
SET status = 'RENTED'
WHERE CURRENT OF copy_csr;
INSERT INTO rental (book_date, copy_id, member_id,
PROCEDURE new_member(
lname IN member.last_name%TYPE,
fname IN member.first_name%TYPE DEFAULT NULL,
address IN member.address%TYPE DEFAULT NULL,
city IN member.city%TYPE DEFAULT NULL,
phone IN member.phone%TYPE DEFAULT NULL) IS
BEGIN
INSERT INTO member(member_id, last_name, first_name,
address, city, phone, join_date)
VALUES(member_id_seq.NEXTVAL, lname, fname,
address, city, phone, SYSDATE);
COMMIT;
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-33
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B: Additional Practice 3 Solutions (continued)
EXCEPTION
WHEN OTHERS THEN
exception_handler(SQLCODE, 'NEW_MEMBER');
END new_member;
END video_pkg;
/
SHOW ERRORS
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-34
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B: Additional Practice 4 Solutions
4. Use the following scripts located in the E:\labs\PLPU\soln directory to test your
routines:
26-FEB-04
PL/SQL procedure successfully completed.
26-FEB-04
PL/SQL procedure successfully completed.
ERROR at line 1:
ORA-20002: NEW_RENTAL has attempted to use a foreign key value that is
invalid
ORA-06512: at "ORA1.VIDEO_PKG", line 9
ORA-06512: at "ORA1.VIDEO_PKG", line 103
ORA-06512: at line 1
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-35
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B: Additional Practice 4 Solutions (continued)
ERROR at line 1:
ORA-20999: Unhandled error in RETURN_MOVIE. Please contact your
application administrator with the following information: ORA-01403: no
data found
ORA-06512: at "ORA1.VIDEO_PKG", line 12
ORA-06512: at "ORA1.VIDEO_PKG", line 69
ORA-06512: at line 1
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-36
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B: Additional Practice 5 Solutions
5. The business hours for the video store are 8:00 a.m. to 10:00 p.m., Sunday through Friday,
and 8:00 a.m. to 12:00 a.m. on Saturday. To ensure that the tables can be modified only
during these hours, create a stored procedure that is called by triggers on the tables.
a. Create a stored procedure called TIME_CHECK that checks the current time against
business hours. If the current time is not within business hours, use the
RAISE_APPLICATION_ERROR procedure to give an appropriate message.
CREATE OR REPLACE PROCEDURE time_check IS
Procedure created.
No errors.
b. Create a trigger on each of the five tables. Fire the trigger before data is inserted, updated,
and deleted from the tables. Call your TIME_CHECK procedure from each of these
triggers.
CREATE OR REPLACE TRIGGER member_trig
BEFORE INSERT OR UPDATE OR DELETE ON member
CALL time_check
/
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-37
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B: Additional Practice 5 Solutions (continued)
CREATE OR REPLACE TRIGGER reservation_trig
BEFORE INSERT OR UPDATE OR DELETE ON reservation
CALL time_check
/
Trigger created.
Trigger created.
Trigger created.
Trigger created.
Note: In order for your trigger to fail, you may need to change the time to be outside the
range of your current time in class. For example, while testing, you may want valid video
hours in your trigger to be from 6:00 p.m. to 8:00 a.m.
-- First determine current timezone and time
SELECT SESSIONTIMEZONE,
TO_CHAR(CURRENT_DATE, 'DD-MON-YYYY HH24:MI') CURR_DATE
FROM DUAL;
-- Change your time zone usinge [+|-]HH:MI format such that the current
-- time returns a time between 6pm and 8am
ALTER SESSION SET TIME_ZONE='-07:00';
Session altered.
SELECT SESSIONTIMEZONE,
TO_CHAR(CURRENT_DATE, 'DD-MON-YYYY HH24:MI') CURR_DATE
FROM DUAL;
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-38
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B: Additional Practice 5 Solutions (continued)
-- Add a new member (for a sample test)
EXECUTE video_pkg.new_member('Elias', 'Elliane', 'Vine Street',
'California', '789-123-4567')
ERROR at line 1:
Session altered.
Oracle
Development Program (WDP) eKitDatabase
materials are 10g: Develop
provided PL/SQL
for WDP in-class Program
use only. Units
Copying eKit APS-39
materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Oracle University and SQL Star International Limited use onlyฺ
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Additional
Practice
Solutions
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Oracle University and SQL Star International Limited use onlyฺ
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Additional Practice 1 and 2: Solutions
1. Evaluate each of the following declarations. Determine which of them are not legal
and explain why.
a. DECLARE
name,dept VARCHAR2(14);
This is illegal because only one identifier per declaration is allowed.
b. DECLARE
test NUMBER(5);
This is legal.
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle
violation of Oracle copyright. Database
All WDP 10g:
students must Develop
receive PL/SQLwith
an eKit watermarked Program
their name Units
and email.APS-3
Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Additional Practice 3: Solutions
3. DECLARE
custid NUMBER(4) := 1600;
custname VARCHAR2(300) := 'Women Sports Club';
new_custid NUMBER(3) := 500;
BEGIN
DECLARE
custid NUMBER(4) := 0;
custname VARCHAR2(300) := 'Shape up Sports Club';
1
END;
custid := (custid *12) / 10;
2 END;
/
Evaluate the PL/SQL block given above and determine the data type and value of each
of the following variables, according to the rules of scoping:
a. The value of CUSTID at position 1 is:
300, and the data type is NUMBER
b. The value of CUSTNAME at position 1 is:
Shape up Sports Club Jansports Club, and the data type is VARCHAR2
c. The value of NEW_CUSTID at position 2 is:
500, and the data type is NUMBER (or INTEGER)
d. The value of NEW_CUSTNAME at position 1 is:
Jansports Club, and the data type is VARCHAR2
e. The value of CUSTID at position 2 is:
1920, and the data type is NUMBER
f. The value of CUSTNAME at position 2 is:
Women Sports Club, and the data type is VARCHAR2
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle
violation of Oracle copyright. Database
All WDP 10g:
students must Develop
receive PL/SQLwith
an eKit watermarked Program
their name Units
and email.APS-4
Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Additional Practice 4: Solutions
4. Write a PL/SQL block to accept a year and check whether it is a leap year. For
example, if the year entered is 1990, the output should be “1990 is not a leap
year.”
Hint: The year should be exactly divisible by 4 but not divisible by 100, or it
should be divisible by 400.
Test your solution with the following years:
1990 Not a leap year
2000 Leap year
1996 Leap year
SET SERVEROUTPUT ON
DECLARE
YEAR NUMBER(4) := &P_YEAR;
REMAINDER1 NUMBER(5,2);
REMAINDER2 NUMBER(5,2);
REMAINDER3 NUMBER(5,2);
BEGIN
REMAINDER1 := MOD(YEAR,4);
REMAINDER2 := MOD(YEAR,100);
REMAINDER3 := MOD(YEAR,400);
IF ((REMAINDER1 = 0 AND REMAINDER2 <> 0 )
OR REMAINDER3 = 0) THEN
DBMS_OUTPUT.PUT_LINE(YEAR || ' is a leap year');
ELSE
DBMS_OUTPUT.PUT_LINE (YEAR || ' is not a leap
year');
END IF;
END;
/
SET SERVEROUTPUT OFF
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle
violation of Oracle copyright. Database
All WDP 10g:
students must Develop
receive PL/SQLwith
an eKit watermarked Program
their name Units
and email.APS-5
Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Additional Practice 5: Solutions
5. a. For the exercises below, you require a temporary table to store the results.
You can either create the table yourself or run the lab_ap_05.sql script
that will create the table for you. Create a table named TEMP with the
following three columns:
Column Name NUM_STORE CHAR_STORE DATE_STORE
Key Type
Nulls/Unique
FK Table
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle
violation of Oracle copyright. Database
All WDP 10g:
students must Develop
receive PL/SQLwith
an eKit watermarked Program
their name Units
and email.APS-6
Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Additional Practices 6 and 7 Solutions
6. a. Store a department number in an iSQL*Plus substitution variable.
DEFINE P_DEPTNO = 30
b. Write a PL/SQL block to print the number of people working in that
department.
Hint: Enable DBMS_OUTPUT in iSQL*Plus with SET SERVEROUTPUT
ON.
SET SERVEROUTPUT ON
DECLARE
HOWMANY NUMBER(3);
7. Write a PL/SQL block to declare a variable called sal to store the salary of an
employee. In the executable part of the program, perform the following tasks:
a. Store an employee name in an iSQL*Plus substitution variable:
SET SERVEROUTPUT ON
DEFINE P_LASTNAME = Pataballa
b. Store his or her salary in the sal variable.
c. If the salary is less than 3,000, give the employee a raise of 500 and
display the message “<Employee Name>’s salary updated” in the
window.
d. If the salary is more than 3,000, print the employee’s salary in the format,
“<Employee Name> earns …...………”
e. Test the PL/SQL block for the last names.
LAST_NAME SALARY
Pataballa 4800
Greenberg 12000
Ernst 6000
Note: Undefine the variable that stores the employee’s name at the end of
the script.
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle
violation of Oracle copyright. Database
All WDP 10g:
students must Develop
receive PL/SQLwith
an eKit watermarked Program
their name Units
and email.APS-7
Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Additional Practices 7 and 8: Solutions
DECLARE
SAL NUMBER(7,2);
LASTNAME EMPLOYEES.LAST_NAME%TYPE;
BEGIN
SELECT salary INTO SAL
FROM employees
WHERE last_name = INITCAP('&&P_LASTNAME') FOR
UPDATE of salary;
LASTNAME := INITCAP('&P_LASTNAME');
• Display the amount of the bonus in the window in the following format:
“The bonus is $………………..”
• Test the PL/SQL for the following test cases:
SALARY BONUS
5000 2000
1000 1000
15000 2000
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle
violation of Oracle copyright. Database
All WDP 10g:
students must Develop
receive PL/SQLwith
an eKit watermarked Program
their name Units
and email.APS-8
Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Additional Practices 8 and 9: Solutions
SET SERVEROUTPUT ON
DEFINE P_SALARY = 5000
DECLARE
SAL NUMBER(7,2) := &P_SALARY;
BONUS NUMBER(7,2);
ANN_SALARY NUMBER(15,2);
BEGIN
ANN_SALARY := SAL * 12;
IF ANN_SALARY >= 20000 THEN
BONUS := 2000;
ELSIF ANN_SALARY <= 19999 AND ANN_SALARY >=10000 THEN
b. Update the department ID of the employee with the new department number,
and update the salary with the new salary. Use the emp table for the updates.
After the update is complete, display the message “Update complete” in the
window. If no matching records are found, display the message “No Data
Found.” Test the PL/SQL block for the following test cases.
EMPLOYEE_ID NEW_DEPARTMENT_ID % INCREASE MESSAGE
100 20 2 Update
Complete
10 30 5 No Data
found
126 40 3 Update
Complete
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle
violation of Oracle copyright. Database
All WDP 10g:
students must Develop
receive PL/SQLwith
an eKit watermarked Program
their name Units
and email.APS-9
Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Additional Practices 9 and 10: Solutions
DECLARE
EMPNO emp.EMPLOYEE_ID%TYPE := &P_EMPNO;
NEW_DEPTNO emp.DEPARTMENT_ID%TYPE :=
&P_NEW_DEPTNO;
PER_INCREASE NUMBER(7,2) := & P_PER_INCREASE;
BEGIN
UPDATE emp
SET department_id = NEW_DEPTNO,
salary = salary + (salary * PER_INCREASE/100)
WHERE employee_id = EMPNO;
10. Create a PL/SQL block to declare an EMP_CUR cursor to select the employee
name, salary, and hire date from the employees table. Process each row from the
cursor, and if the salary is greater than 15,000 and the hire date is greater than 01-
FEB-1988, display the employee name, salary, and hire date in the window.
SET SERVEROUTPUT ON
DECLARE
CURSOR EMP_CUR IS
SELECT last_name,salary,hire_date FROM EMPLOYEES;
ENAME VARCHAR2(25);
SAL NUMBER(7,2);
HIREDATE DATE;
BEGIN
OPEN EMP_CUR;
FETCH EMP_CUR INTO ENAME,SAL,HIREDATE;
WHILE EMP_CUR%FOUND
LOOP
IF SAL > 15000 AND HIREDATE >= TO_DATE('01-FEB-
1988','DD-MON-
YYYY') THEN
DBMS_OUTPUT.PUT_LINE (ENAME || ' earns ' ||
TO_CHAR(SAL)||
' and joined the organization on ' ||
TO_DATE(HIREDATE,'DD-
Mon-YYYY'));
END IF;
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle
violation of Oracle copyright. Database
All WDP 10g:
students must Develop
receive PL/SQL with
an eKit watermarked Program
their nameUnits APS-10
and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Additional Practices 10 and 11: Solutions
FETCH EMP_CUR INTO ENAME,SAL,HIREDATE;
END LOOP;
CLOSE EMP_CUR;
END;
/
SET SERVEROUTPUT OFF
11. Create a PL/SQL block to retrieve the last name and department ID of each
employee from the employees table for those employees whose EMPLOYEE_ID
is less than 114. From the values retrieved from the employees table, populate
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle
violation of Oracle copyright. Database
All WDP 10g:
students must Develop
receive PL/SQL with
an eKit watermarked Program
their nameUnits APS-11
and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Additional Practices 11 and 12: Solutions
FOR i IN 1..TRACK
LOOP
DBMS_OUTPUT.PUT_LINE ('Employee Name: ' ||
Tename(i) || ' Department_id: ' || Tdept(i));
END LOOP;
END;
/
SET SERVEROUTPUT OFF
b. Test the PL/SQL block for the following hire dates: 08-MAR-00, 25-JUN-97,
28-SEP-98, 07-FEB-99.
DECLARE
CURSOR DATE_CURSOR(JOIN_DATE DATE) IS
SELECT employee_id,last_name,hire_date FROM
employees
WHERE HIRE_DATE >JOIN_DATE ;
EMPNO employees.employee_id%TYPE;
ENAME employees.last_name%TYPE;
HIREDATE employees.hire_date%TYPE;
HDATE employees.hire_date%TYPE := '&P_HIREDATE';
BEGIN
OPEN DATE_CURSOR(HDATE);
LOOP
FETCH DATE_CURSOR INTO EMPNO,ENAME,HIREDATE;
EXIT WHEN DATE_CURSOR%NOTFOUND;
DBMS_OUTPUT.PUT_LINE (EMPNO || ' ' || ENAME || '
' ||
HIREDATE);
END LOOP;
END;
/
SET SERVEROUTPUT OFF;
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle
violation of Oracle copyright. Database
All WDP 10g:
students must Develop
receive PL/SQL with
an eKit watermarked Program
their nameUnits APS-12
and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Additional Practice 13: Solutions
13. Execute the lab_ap_09_a.sql script to re-create the emp table. Create a
PL/SQL block to promote clerks who earn more than 3,000 to SR CLERK and
increase their salaries by 10%. Use the emp table for this practice. Verify the
results by querying on the emp table.
Hint: Use a cursor with FOR UPDATE and CURRENT OF syntax.
DECLARE
CURSOR Senior_Clerk IS
SELECT employee_id,job_id FROM emp
WHERE job_id = 'ST_CLERK' AND salary > 3000
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle
violation of Oracle copyright. Database
All WDP 10g:
students must Develop
receive PL/SQL with
an eKit watermarked Program
their nameUnits APS-13
and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Additional Practice 14: Solutions
14. a. For the following exercise, you require a table to store the results. You can
create the analysis table yourself or run the lab_ap_14_a.sql script
that creates the table for you. Create a table called analysis with the
following three columns:
Column Name ENAME YEARS SAL
Key Type
Nulls/Unique
FK Table
b. Create a PL/SQL block to populate the analysis table with the information
from the employees table. Use an iSQL*Plus substitution variable to store an
employee’s last name.
SET SERVEROUTPUT ON
DEFINE P_ENAME = Austin
c. Query the employees table to find if the number of years that the employee
has been with the organization is greater than five, and if the salary is less than
3,500, raise an exception. Handle the exception with an appropriate exception
handler that inserts the following values into the analysis table: employee
last name, number of years of service, and the current salary. Otherwise,
display Not due for a raise in the window. Verify the results by
querying the analysis table. Use the following test cases to test the PL/SQL
block.
LAST_NAME MESSAGE
Austin Not due for a raise
Nayer Not due for a raise
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle
violation of Oracle copyright. Database
All WDP 10g:
students must Develop
receive PL/SQL with
an eKit watermarked Program
their nameUnits APS-14
and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Additional Practice 14: Solutions (continued)
DECLARE
DUE_FOR_RAISE EXCEPTION;
HIREDATE EMPLOYEES.HIRE_DATE%TYPE;
ENAME EMPLOYEES.LAST_NAME%TYPE := INITCAP(
'&P_ENAME');
SAL EMPLOYEES.SALARY%TYPE;
YEARS NUMBER(2);
BEGIN
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle
violation of Oracle copyright. Database
All WDP 10g:
students must Develop
receive PL/SQL with
an eKit watermarked Program
their nameUnits APS-15
and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Oracle University and SQL Star International Limited use onlyฺ
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Additional Practices:
Table Descriptions
and Data
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
violation of Oracle copyright. All WDP students must receive an eKit watermarked with their name and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part A
The tables and data used in part A are the same as those in Appendix B, “Table
Descriptions and Data.”
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle
violation of Oracle Database
copyright. 10g: Develop
All WDP students must receive PL/SQL Program
an eKit watermarked with Units
their nameTable Descriptions-2
and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B: Tables Used
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle
violation of Oracle Database
copyright. 10g: Develop
All WDP students must receive PL/SQL Program
an eKit watermarked with Units
their nameTable Descriptions-3
and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B: MEMBER Table
DESCRIBE member
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle
violation of Oracle Database
copyright. 10g: Develop
All WDP students must receive PL/SQL Program
an eKit watermarked with Units
their nameTable Descriptions-4
and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B: RENTAL Table
DESCRIBE rental
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle
violation of Oracle Database
copyright. 10g: Develop
All WDP students must receive PL/SQL Program
an eKit watermarked with Units
their nameTable Descriptions-5
and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B: RESERVATION Table
DESCRIBE reservation
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle
violation of Oracle Database
copyright. 10g: Develop
All WDP students must receive PL/SQL Program
an eKit watermarked with Units
their nameTable Descriptions-6
and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B: TITLE Table
DESCRIBE title
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle
violation of Oracle Database
copyright. 10g: Develop
All WDP students must receive PL/SQL Program
an eKit watermarked with Units
their nameTable Descriptions-7
and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.
Part B: TITLE_COPY Table
DESCRIBE title_copy
Development Program (WDP) eKit materials are provided for WDP in-class use only. Copying eKit materials is strictly prohibited and is in
Oracle
violation of Oracle Database
copyright. 10g: Develop
All WDP students must receive PL/SQL Program
an eKit watermarked with Units
their nameTable Descriptions-8
and email. Contact
OracleWDP_ww@oracle.com if you have not received your personalized eKit.