rules repository

G-6010

🆓
Warning

Always use a character variable to execute dynamic SQL.

Reason

Having the executed statement in a variable makes it easier to debug your code (e.g. by logging the statement that failed).

Example

Non-Compliant Example

declare
   l_next_val employees.employee_id%type;
begin
   execute immediate 'select employees_seq.nextval from dual'
      into l_next_val;
end;
/
Issues
LineColumnMessage
422Use a variable instead of a literal to execute dynamic SQL.

Compliant Solution - ★★★★★

declare
   l_next_val employees.employee_id%type;
   co_sql     constant types_up.big_string_type :=
      'select employees_seq.nextval from dual';
begin
   execute immediate co_sql into l_next_val;
end;
/

References