Who Can Drop a Package
The DROP PACKAGE statement can be executed by:
- 
The owner of the package 
- 
Users with the DROP ANY PACKAGEprivilege
The DROP PACKAGE statement can be executed by:
The owner of the package
Users with the DROP ANY PACKAGE privilege
DROP PACKAGEDROP PACKAGE APP_VARRECREATE PACKAGEDrops a package header if it exists, and creates a package header
DSQL
RECREATE PACKAGE package_name
[SQL SECURITY {INVOKER | DEFINER}]
AS
BEGIN
  [ <package_item> ... ]
END
!! See syntax of CREATE PACKAGE for further rules!!
The RECREATE PACKAGE statement creates a new package or recreates an existing package header.If a package header with the same name already exists, then this statement will first drop it and then create a new package header.It is not possible to recreate the package header if there are still dependencies on the existing package, or if the body of the package exists.Existing privileges of the package itself are not preserved, nor are privileges to execute the procedures or functions of the package.
RECREATE PACKAGERECREATE PACKAGE APP_VAR
AS
BEGIN
  FUNCTION GET_DATEBEGIN() RETURNS DATE DETERMINISTIC;
  FUNCTION GET_DATEEND() RETURNS DATE DETERMINISTIC;
  PROCEDURE SET_DATERANGE(ADATEBEGIN DATE,
      ADATEEND DATE DEFAULT CURRENT_DATE);
END