INSERT
There are two methods for inserting data into a table from within the database:
When specifying a column list using either method, any non-nullable fields not included in the list will be given default values--empty string for strings, and 0 for numerics. The fields in the column list and the values or fields selected must align.
Tip
INSERT operations will automatically leverage Multi-Head Ingest, when applicable.
See Loading Data for inserting data into a table from sources external to the database.
INSERT INTO ... VALUES
Records with literal values can be inserted into the database.
|
|
|
|
Insert Options
The following options can be specified to modify the way data is inserted (or not inserted) into the target table.
Note
The WITH OPTIONS clause is only valid when used within JDBC.
Option | Description | ||||||||
---|---|---|---|---|---|---|---|---|---|
BATCH SIZE | Use an ingest batch size of the given number of records. The default batch size is 50,000. | ||||||||
ON ERROR | When an error is encountered inserting a record, handle it using one of the following modes. The default mode is ABORT.
|
INSERT INTO ... SELECT
Records that are the result set of a query can be inserted into the database.
|
|
|
|
Upserting
To upsert records, inserting new records and updating existing ones (as denoted by primary key), use the KI_HINT_UPDATE_ON_EXISTING_PK hint. If the target table has no primary key, this hint will be ignored.
Tip
This hint can be specified as the connection option UpdateOnExistingPk when using JDBC/ODBC.
|
|
Important
By default, any record being inserted that matches the primary key of an existing record in the target table will be discarded, and the existing record will remain unchanged. The KI_HINT_UPDATE_ON_EXISTING_PK hint overrides this behavior, favoring the source records over the target ones.
Ignoring Duplicates
To discard duplicate records (as denoted by primary key) when inserting data, use the KI_HINT_IGNORE_EXISTING_PK hint. If the target table has no primary key or if in upsert mode (using KI_HINT_UPDATE_ON_EXISTING_PK), this hint will be ignored.
Tip
Both of these hints can be specified as the connection options IgnoreExistingPk & UpdateOnExistingPk, respectively, when using JDBC/ODBC.
|
|
UPDATE
Updates can set columns to specified constant values or expressions.
|
|
For example, to update employee with ID 5 to have a new manager, with ID 3, and to have a 10% salary increase:
|
|
Subqueries can be used in the expression list and within the SET clause. To update all the bottom earners in each department with a 5% salary increase using a subquery in the expression list:
|
|
To update a backup table to match the source table that was just updated for new salary values using a subquery within the SET clause:
|
|
Joins can be used within an UPDATE statement to update records based on the results of a JOIN.
Important
The JOIN statement cannot be part of the SET clause. Also, primary key column updates are not supported using JOIN operations. The table to be updated must be in the FROM clause.
For example, to update a backup table to match the source table that was just updated for new manager and salary values using an INNER JOIN:
|
|
Tip
Simplified JOIN syntax is also supported:
|
|
Overwriting Duplicates
When updating the primary key value(s) of a record, it is possible for that updated record to collide with another record with the same primary key. To update the original record with the values specified in the SET clause and remove the other existing record with the same primary key, use the KI_HINT_UPDATE_ON_EXISTING_PK hint. If the target table has no primary key, this hint will be ignored.
Tip
This hint can be specified as the connection option UpdateOnExistingPk when using JDBC/ODBC.
|
|
Important
By default, updates resulting in primary key collisions will be rejected, and the existing record(s) will remain unchanged. The KI_HINT_UPDATE_ON_EXISTING_PK hint overrides this behavior, favoring the original record being updated and the new values used to update it, specified in the SET clause, over the other existing record with the same primary key.
Ignoring Duplicates
When updating the primary key value(s) of a record, it is possible for that updated record to collide with another record with the same primary key. To discard updates that result in primary key collisions and not return an error, use the KI_HINT_IGNORE_EXISTING_PK hint. If the target table has no primary key or if using KI_HINT_UPDATE_ON_EXISTING_PK, this hint will be ignored.
Tip
These hints can be specified as connection options (IgnoreExistingPk, UpdateOnExistingPk) when using JDBC/ODBC.
|
|
DELETE
Deletes records from a table.
|
|
For example, to delete employee with ID 6:
|
|
Subqueries can also be used in the expression list. To delete all the most recent hires in each department:
|
|