Available inDSQL, PSQL

    Syntax

    Table 6.4.1 Arguments for the UPDATE OR INSERT Statement Parameters

    UPDATE OR INSERT inserts a new record or updates one or more existing records. The action taken depends on the values provided for the columns in the MATCHING clause (or, if the latter is absent, in the primary key). If there are records found matching those values, they are updated. If not, a new record is inserted. A match only counts if all the values in the MATCHING or primary key columns are equal. Matching is done with the operator, so one NULL matches another.

    Restrictions

    • In the MATCHING list as well as in the update/insert column list, each column name may occur only once.

    • When values are returned into the context variable NEW, this name must not be preceded by a colon ().

    The optional RETURNING clause, if present, need not contain all the columns mentioned in the statement and may also contain other columns or expressions. The returned values reflect any changes that may have been made in BEFORE triggers, but not those in AFTER triggers. OLD.*fieldname* and NEW.*fieldname* may both be used in the list of columns to return; for field names not preceded by either of these, the new value is returned.

    The user executing the statement needs to have SELECT privileges on the columns specified in the RETURNING clause.

    The syntax of the returning_list is similar to the column list of a SELECT clause. It is possible to reference all columns using *, or *table_name*.*, NEW.* and/or .

    In DSQL, a statement with a RETURNING clause always returns exactly one row. If a RETURNING clause is present and more than one matching record is found, an error multiple rows in singleton select is raised. This behaviour may change in a later version of Firebird.

    6.4.2 Example of UPDATE OR INSERT

    Modifying data in a table, using UPDATE OR INSERT in a PSQL module. The return value is passed to a local variable, whose colon prefix is optional.

    1. UPDATE OR INSERT INTO Cows (Name, Number, Location)
    2. VALUES ('Suzy Creamcheese', 3278823, 'Green Pastures')
    3. MATCHING (Number)
    4. UPDATE OR INSERT INTO Cows (Name, Number, Location)
    5. VALUES ('Suzy Creamcheese', 3278823, 'Green Pastures')