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