UPDATE
The UPDATE statement page describes the following:
Overview
The UPDATE statement is used to modify the value of certain columns in existing rows without creating a table.
It can be used to do the following:
- Performing localized changes in existing data, such as correcting mistakes discovered after ingesting data. 
- Setting columns based on the values of others. 
Warning
Using the UPDATE command on column clustered using a cluster key can undo your clustering.
The UPDATE statement cannot be used to reference other tables in the WHERE or SET clauses.
Syntax
The following is the correct syntax for the UPDATE command:
UPDATE target_table_name [[AS] alias1]
SET column_name = expression [,...]
[FROM additional_table_name [[AS] alias2][,...]]
[WHERE condition]
Parameters
The following table describes the UPDATE parameters:
| Parameter | Description | 
|---|---|
| 
 | Specifies the table containing the data to be updated. | 
| 
 | Specifies the column containing the data to be updated. | 
| 
 | Additional tables used in the WHERE condition for performing complex joins. | 
| 
 | Specifies the condition for updating the data. | 
Examples
The examples section shows how to modify the value of certain columns in existing rows without creating a table.
To be able to follow the examples, create these two tables:
countries
| id | name | records_sold | 
|---|---|---|
| 1 | Israel | 0 | 
| 2 | UK | 0 | 
| 3 | USA | 0 | 
| 4 | Sweden | 0 | 
bands
| id | name | country_id | 
|---|---|---|
| 1 | The Beatles | 2 | 
| 2 | The Ramones | 3 | 
| 3 | ABBA | 4 | 
| 4 | Ace of Base | 4 | 
create or replace table countries ( id int, name text, records_sold int);
insert into countries values (1, 'Israel', 0);
insert into countries values (2, 'UK', 0);
insert into countries values (3, 'USA', 0);
insert into countries values (4, 'Sweden', 0);
create or replace table bands ( id int, name text, country_id int);
insert into bands values (1, 'The Beatles', 2);
insert into bands values (2, 'The Ramones', 3);
insert into bands values (3, 'ABBA', 4);
insert into bands values (4, 'Ace of Base', 4);
Updating an Entire Table
Two different UPDATE methods for updating an entire table.
UPDATE countries SET records_sold = 0;
UPDATE countries SET records_sold = 0 WHERE true;
Performing Simple Updates
The following is an example of performing a simple update:
UPDATE countries SET records_sold = records_sold + 1 WHERE name = 'Israel';
Updating Tables that Contain Multi-Table Conditions
The following shows an example of updating tables that contain multi-table conditions:
UPDATE countries
SET records_sold = records_sold + 1
WHERE EXISTS (
  SELECT 1 FROM bands
  WHERE bands.country_id = countries.id
  AND bands.name = 'ABBA'
);
Updating Tables that Contain Multi-Table Expressions
The following shows an example of updating tables that contain multi-table expressions:
UPDATE countries
SET records_sold = records_sold +
  CASE
        WHEN name = 'Israel' THEN 2
        ELSE 1
  END
FROM countries c
;
Triggering a Cleanup
When an UPDATE statement is executed, it creates new chunks that contain the updated data. As a result, residual data may be left behind, and a cleanup operation is necessary to complete the physical removal of data.
This cleanup is usually done automatically overnight, but you can choose to do so yourself to remove the redundant files immediately.
The following is the syntax for triggering a cleanup:
SELECT cleanup_chunks('schema_name','table_name');
SELECT cleanup_extents('schema_name','table_name');
Permissions
Executing an UPDATE statement requires the following permissions:
- Both - UPDATEand- SELECTpermissions on the target table.
- The - SELECTpermission for each additional table you reference in the statement (in either the- FROMclause or- WHEREsubquery section).
Locking and Concurrency
Executing the UPDATE statement obtains an exclusive UPDATE lock on the target table, but does not lock the destination tables.