RETURNING Clause

RETURNING Clause

The RETURNING clause returns the affected rows from INSERT, UPDATE, and DELETE operations without requiring a separate SELECT query.

INSERT RETURNING

Return the inserted rows:

INSERT INTO users VALUES (1, 'Alice', 100)
RETURNING id, name;
-- Returns: id=1, name='Alice'

Works with multi-row inserts:

INSERT INTO items VALUES (1, 100), (2, 200), (3, 300)
RETURNING id, value;
-- Returns all 3 inserted rows

Return a subset of columns:

INSERT INTO records VALUES (1, 'a', 'b', 'c')
RETURNING id;
-- Returns only the id column

UPDATE RETURNING

Return the updated rows with their new values:

UPDATE counters SET count = count + 5 WHERE id = 1
RETURNING id, count;
-- Returns: id=1, count=<new value>

Returns all rows that matched the WHERE clause:

UPDATE scores SET score = score * 2 WHERE score >= 200
RETURNING id, score;
-- Returns multiple updated rows

If no rows match, returns an empty result set:

UPDATE data SET value = 999 WHERE id = 999
RETURNING id, value;
-- Returns empty result set

DELETE RETURNING

Return the deleted rows (with their values before deletion):

DELETE FROM items WHERE id = 1
RETURNING id, name;
-- Returns the deleted row's data

Return multiple deleted rows:

DELETE FROM products WHERE category = 'discontinued'
RETURNING id, name, price;
-- Returns all deleted rows

Use Cases

  • Get auto-generated IDs after INSERT without a separate SELECT
  • Verify updates by seeing the new values in a single round-trip
  • Audit deletes by capturing deleted data for logging
  • Build pipelines by chaining DML results into application logic