rules repository

G-7125

🆓
Warning

Always use CREATE OR REPLACE instead of CREATE alone.

Reason

Using create alone makes your scripts give an error if the program unit already exists, which makes the script not repeatable. It is good practice to use create or replace to avoid such errors.

Example

Non-Compliant Example

create package body employee_api is
   function employee_by_id(in_employee_id in integer) -- NOSONAR G-7460: non-deterministic
      return employees%rowtype is
      co_employee_id constant employees.employee_id%type := in_employee_id;
      r_employee     employees%rowtype;
   begin
      select *
        into r_employee
        from employees
       where employee_id = co_employee_id;

      return r_employee;
   exception
      when no_data_found then
         null;
      when too_many_rows then
         raise;
   end employee_by_id;
end employee_api;
/
Issues
LineColumnMessage
11Missing OR REPLACE in CREATE.

Compliant Solution - ★★★★★

create or replace package body employee_api is
   function employee_by_id(in_employee_id in integer) -- NOSONAR G-7460: non-deterministic
      return employees%rowtype is
      co_employee_id constant employees.employee_id%type := in_employee_id;
      r_employee     employees%rowtype;
   begin
      select *
        into r_employee
        from employees
       where employee_id = co_employee_id;

      return r_employee;
   exception
      when no_data_found then
         null;
      when too_many_rows then
         raise;
   end employee_by_id;
end employee_api;
/

References