Search notes:

Oracle SQL: WITH clause

In an SQL statement, a with clause allows to define

Local functions

A with clause allows to declare PL/SQL functions that are local to the SQL statement in which it occurs:
with
   function f (a number, b number) return number is
   begin
      return abs(a) + abs(b);
   end f;
   function g (a number, b number) return number is
   begin
      return f(a-5, b+5);
   end g;
   d as (
     select -4 u,  9 v from dual union all
     select  4 u,  9 v from dual union all
     select -2 u, -8 v from dual union all
     select  1 u,  0 v from dual
   )
select
   u,
   v,
   f(u,v) f,
   g(u,v) g
from
   d
;
Another example …
--
--  Setting a special sql terminator because SQL*Plus is not
--  updated to 12c everywhere...
--
set sqlterminator "!"

create table tq84_inline_function (
  a number,
  b varchar2(10)
)!

insert into tq84_inline_function values ( 5, 'foo')!
insert into tq84_inline_function values ( 7, 'bar')!
insert into tq84_inline_function values ( 2, 'baz')!

with
  function fib(y number) return number as
  begin
     if y<=2 then return 1; end if;
     return fib(y-2) + fib(y-1);
  end fib;
select
  a, fib(a), b
from
  tq84_inline_function
!

drop table tq84_inline_function!
Github repository Oracle-Patterns, path: /SQL/select/with/inline-function/example-01.sql
When using local functions in a with clause to insert data, the with_plsql hint must be used to prevent ORA-32034: unsupported use of WITH clause.
See also pragma inline.

Using the WITH clause together with an INSERT statement

create table tq84_t (col number);

insert into tq84_t
with d as (
   select 42 as num from dual
)
select * from d;

drop table tq84_t;

Combining WITH clause with UNION ALL

The following somewhat silly select statement demonstrates how a WITH clause can be combined with a UNION ALL:
with p as (select 'FOO' nam from dual)
   select 'object', owner      from p, dba_objects      where object_name = p.nam union all
   select 'column', table_name from p, dba_tab_columns  where column_name = p.nam;

See also

In a with clause, the /*+ materialize */ hint forces the data that is returned by its subquery to be stored in a global temporary table.
Using a with clause in a create table as select statement.
The cursor duration temporary tables query transformation.
The error messages
The with clause can be used to prevent ORA-62569: nested polymorphic table function is disallowed
The optimizer feature WITH clause filter predicate pushdown.

Index

Fatal error: Uncaught PDOException: SQLSTATE[HY000]: General error: 8 attempt to write a readonly database in /home/httpd/vhosts/renenyffenegger.ch/php/web-request-database.php:78 Stack trace: #0 /home/httpd/vhosts/renenyffenegger.ch/php/web-request-database.php(78): PDOStatement->execute(Array) #1 /home/httpd/vhosts/renenyffenegger.ch/php/web-request-database.php(30): insert_webrequest_('/notes/developm...', 1761468196, '216.73.216.115', 'Mozilla/5.0 App...', NULL) #2 /home/httpd/vhosts/renenyffenegger.ch/httpsdocs/notes/development/databases/Oracle/SQL/clauses/with/index(142): insert_webrequest() #3 {main} thrown in /home/httpd/vhosts/renenyffenegger.ch/php/web-request-database.php on line 78