Syntax
Parameters
| Parameter | Description |
|---|---|
<table> | The table to insert into. |
( <column_name> [ , ... ] ) | List of column names to be inserted into. If not defined, the columns will be deduced from the expression. |
<expression>—OR— VALUES ( <value> [ , ... ] ) [, ... ] | Either a SELECT query or an explicit list of VALUES tuples to be inserted. |
<settings> | List of query-specific settings overrides. |
INSERT ON CONFLICT
This feature is in public preview.
ON CONFLICT clause provides a way to reconcile or merge new data with existing records by either skipping or overwriting rows that already exist. It is available for a narrow subset of INSERT statements. For more generic UPSERT or deduplication functionality, use the MERGE statement.
Given this clause, for each row proposed for insertion, either the insertion proceeds, or, if there already exists a row in the table matching the tuple specified by the CONFLICT columns, an alternative action will be taken. There are two possible alternatives - take no action, or update the pre-existing matched row(s) in some way.
DO NOTHINGenables anINSERT IGNOREworkload, whereby the newer row is simply discarded.DO UPDATEenables an UPSERT orINSERT UPDATEworkload, whereby the pre-existing matched row(s) can be partially or fully overwritten. The overwrite expressions can (but do not have to) reference the fresh data using theEXCLUDEDview name.DO UPDATE SET *can replace the exhaustiveSET colA = EXCLUDED.colA, colB = EXCLUDED.colB, ... , colN = EXCLUDED.colNif no data transformation is required.
Extra Parameters
| Parameter | Description |
|---|---|
( <conflict_column_name> [ , ... ] ) | List of column names to determine CONFLICT duplicates |
<conflict_action> | Action to take when a conflict occurs: DO NOTHING to skip the conflicting row, or DO UPDATE SET to update the existing matched row(s). |
INSERT ON CONFLICT Limitations:
INSERTexpression must be a singleVALUEStuple.- At least one
CONFLICTcolumn must be specified. These are not automatically deduced from primary index, etc. - Unless using
INSERT *, theINSERTcolumn list must be specified. Their names and ordering cannot get deduced fromVALUES.
Examples
First, create a table populated with student information as follows:INSERT to add two rows into the students table as follows:
dob column for date of birth does not have default value, so Firebolt sets it to NULL.
Settings to control behavior
insert_shardingto enforce partition locality during ingestion into partitioned tables.tablet_min_size_bytesandtablet_max_size_bytesto control min/max tablet sizes during ingestion.max_insert_threadsto control the maximum number of threads forINSERTstatements, limiting the degree of parallelism for tablet writing operations. This can reduce memory footprint during ingestion.