2005-07-05 10:02:01 +02:00
|
|
|
----------------
|
|
|
|
RETURNING clause
|
|
|
|
----------------
|
|
|
|
|
|
|
|
Function:
|
2007-04-24 17:22:05 +02:00
|
|
|
Allow to return the column values actually stored in the table as a result of the "INSERT",
|
2011-10-23 03:31:11 +02:00
|
|
|
"UPDATE OR INSERT", UPDATE, DELETE and MERGE statements.
|
2005-07-05 10:02:01 +02:00
|
|
|
The most common usage is to retrieve the value of the primary key generated inside a BEFORE-trigger.
|
|
|
|
|
2007-04-24 17:22:05 +02:00
|
|
|
Authors:
|
2005-07-05 10:02:01 +02:00
|
|
|
Dmitry Yemanov <yemanov@yandex.ru>
|
2007-04-24 17:22:05 +02:00
|
|
|
Adriano dos Santos Fernandes <adrianosf@uol.com.br>
|
2005-07-05 10:02:01 +02:00
|
|
|
|
|
|
|
Syntax rules:
|
2013-04-26 17:52:23 +02:00
|
|
|
INSERT INTO ... VALUES (...) [RETURNING <returning_list> [INTO <variable_list>]]
|
|
|
|
INSERT INTO ... SELECT ... [RETURNING <returning_list> [INTO <variable_list>]]
|
|
|
|
UPDATE OR INSERT INTO ... VALUES (...) ... [RETURNING <returning_list> [INTO <variable_list>]]
|
|
|
|
UPDATE ... [RETURNING <returning_list> [INTO <variable_list>]]
|
|
|
|
DELETE FROM ... [RETURNING <returning_list> [INTO <variable_list>]]
|
|
|
|
MERGE INTO ... [RETURNING <returning_list> [INTO <variable_list>]]
|
|
|
|
|
|
|
|
<returning_list> ::= <expr> [[AS] <alias>] {, <expr> [[AS] <alias>]}...
|
2005-07-05 10:02:01 +02:00
|
|
|
|
|
|
|
Scope:
|
|
|
|
DSQL, PSQL
|
|
|
|
|
|
|
|
Example(s):
|
|
|
|
1. INSERT INTO T1 (F1, F2)
|
|
|
|
VALUES (:F1, :F2)
|
|
|
|
RETURNING F1, F2 INTO :V1, :V2;
|
|
|
|
2. INSERT INTO T2 (F1, F2)
|
|
|
|
VALUES (1, 2)
|
|
|
|
RETURNING ID INTO :PK;
|
2007-04-24 17:22:05 +02:00
|
|
|
3. DELETE FROM T1 WHERE F1 = 1 RETURNING F2;
|
|
|
|
4. UPDATE T1 SET F2 = F2 * 10 RETURNING OLD.F2, NEW.F2;
|
2013-04-26 17:52:23 +02:00
|
|
|
5. UPDATE T1 SET F2 = F2 * 10 RETURNING OLD.F2 OLD_F2, NEW.F2 AS NEW_F2;
|
|
|
|
6. UPDATE T1 SET F2 = F2 * 10 WHERE CURRENT OF C RETURNING NEW.F2;
|
2005-07-05 10:02:01 +02:00
|
|
|
|
|
|
|
Note(s):
|
|
|
|
1. The INTO part (i.e. the variable list) is allowed in PSQL only (to assign local variables)
|
|
|
|
and rejected in DSQL.
|
2021-08-25 19:41:25 +02:00
|
|
|
2. In DSQL, INSERT INTO ... VALUES are returned within the same protocol roundtrip as the
|
|
|
|
INSERT is executed - this is not the case for INSERT INTO ... SELECT.
|
2005-07-05 10:02:01 +02:00
|
|
|
3. If the RETURNING clause is present, then the statement is described as
|
2021-08-25 19:41:25 +02:00
|
|
|
isc_info_sql_stmt_exec_procedure by the API (for INSERT INTO ... VALUES and statements
|
|
|
|
with WHERE CURRENT OF) and isc_info_sql_stmt_select for the others statements, so the
|
|
|
|
existing connectivity drivers should support this feature automagically.
|
2005-07-05 10:02:01 +02:00
|
|
|
4. Any explicit record change (update or delete) performed by AFTER-triggers is ignored by
|
|
|
|
the RETURNING clause.
|
2011-10-23 03:31:11 +02:00
|
|
|
5. OLD and NEW could be used in RETURNING clause of UPDATE, INSERT OR UPDATE and MERGE statements.
|
2007-04-24 17:22:05 +02:00
|
|
|
6. In UPDATE and INSERT OR UPDATE statements, unqualified or qualified by table name/alias
|
|
|
|
fields are resolved to NEW.
|
2011-10-23 03:31:11 +02:00
|
|
|
7. In MERGE WHEN MATCHED UPDATE and MERGE WHEN NOT MATCHED statements, unqualified or qualified
|
|
|
|
by table name/alias fields are resolved to NEW. In MERGE WHEN MATCHED DELETE they are
|
|
|
|
resolved to OLD.
|
2019-01-22 15:20:42 +01:00
|
|
|
8. Since v4 it's possible to use * and alias.*, as well OLD.* and NEW.* where applicable.
|
2021-08-25 19:41:25 +02:00
|
|
|
9. ORDER BY works with fields from the OLD context (the original record source before changes are applied).
|
2007-04-24 17:22:05 +02:00
|
|
|
|
|
|
|
Limitations:
|
2021-08-25 19:41:25 +02:00
|
|
|
1. The modify statement (INSERT, UPDATE, DELETE, UPDATE OR INSERT, MERGE) in PSQL should
|
|
|
|
operate in no more than one record (i.e. should be singleton).
|
|
|
|
|
|
|
|
Changes in v5:
|
|
|
|
1. Ability to return multiple rows (or no row) in DSQL.
|
|
|
|
2. Added PLAN and ORDER BY subclauses to MERGE.
|
|
|
|
3. Added PLAN, ORDER BY and ROWS subclauses to UPDATE OR INSERT.
|