This document covers the following topics:
Belongs to Function Group: Database Access and Update
See also DELETE - SQL in the Natural for Db2 part of the Database Management System Interfaces documentation:
The SQL DELETE statement is used to delete either rows in a table without
                            using a cursor ("searched"
                                 DELETE) or rows in a table to which a cursor is positioned
                              ("positioned"
                                 DELETE).
               
Two different structures are possible.
The "searched"
                            DELETE statement is a stand-alone statement not related to any SELECT statement. With a single statement
                            you can delete zero, one, multiple or all rows of a table. The rows to be deleted are
                            determined by a search-condition that is applied
                            to the table. Optionally, the table name can be assigned a
                                correlation-name.
               
Note
 The number of rows that have actually been deleted with a "searched"
                               DELETE can be ascertained by using the system variable *ROWCOUNT; see
                                 System Variables documentation.
                  
Common Set Syntax:
| DELETEFROMtable-name [correlation-name] [WHEREsearch-condition] | 
Extended Set Syntax:
| DELETEFROMtable-name [period-clause] [correlation-name] | |||||||
| [include-columns [ SETassignment-clause]] | |||||||
| [ WHEREsearch-condition] | |||||||
| [ FETCH
                                                         FIRSTrow-limit] | |||||||
| 
 | WITH | 
 | 
 | 
 | [ SKIP LOCKED DATA] [QUERYNOinteger] | ||
For an explanation of the symbols used in the syntax diagram, see Syntax Symbols.
Syntax Element Description:
| Syntax Element | Description | |
|---|---|---|
| FROM
                                                      table-name |  FROM Clause: Specifies the table from which the rows are to be deleted. | |
| period-clause | Period Clause: Specifies that a period clause applies to the target of the update operation. For further information, see Period Clause in the section Basic Syntactical Items. | |
| correlation-name | Correlation Name: Optional. The table name can be assigned a correlation-name. | |
| include-columns | Include Columns Clause: Optional. Specifies a set of columns that are included, along with the columns
                                                  of  For further details, see include-columns. | |
| SET
                                                      assignment-clause | SET Assignment Clause: Introduces the assignment of values to the included columns of the
                                                       | |
| WHERE
                                                      search-condition |  WHERE Clause: Specifies the selection criteria for the rows to be deleted. If no  | |
| FETCH FIRST |  FETCH FIRST Clause: Limits the effects of the  It corresponds to the  | |
| WITH |  WITH Isolation Level Clause: Enables the explicit specification of the isolation level used when locating the row to be deleted. This clause belongs to the SQL Extended Set. | |
| CS | Cursor Stability | |
| RR | Repeatable Read | |
| RS | Read Stability | |
| SKIP LOCKED
                                                  DATA | SKIP LOCKED DATA Clause: Specifies that rows are skipped when incompatible locks are held on the row by other transactions. | |
| QUERYNO integer |  QUERYNO Clause: This clause belongs to the SQL Extended Set. This clause explicitly specifies the number to be used in
                                                     | |
The "positioned"
                            DELETE statement always refers to a cursor within a database loop. Therefore
                            the table referenced by a positioned DELETE statement must be the same as the
                            one referenced by the corresponding SELECT statement, otherwise an error message is returned. A
                            positioned DELETE cannot be used with a non-cursor selection.
               
The functionality of the positioned DELETE statement corresponds to that of
                            the "native" Natural DELETE
                                 statement.
               
Common Set Syntax:
| DELETE FROMtable-nameWHERE CURRENT OF CURSOR[(r)] | 
Extended Set Syntax:
| DELETE FROMtable-nameWHERE CURRENT OF CURSOR[(r)] | 
 | FOR
                                                       ROW | 
 | 
 | OF
                                                       ROWSET | 
 | ||
For an explanation of the symbols used in the syntax diagram, see Syntax Symbols.
Syntax Element Description:
| Syntax Element | Description | 
|---|---|
| FROM
                                                      table-name WHERE CURRENT OF
                                                  CURSOR |  FROM Clause: This clause specifies the table from which the rows are to be deleted. | 
| (r) |  Statement Reference: The  | 
| FOR
                                                    ROW ... OF ROWSET |  FOR ROW … OF ROWSET Clause: This clause belongs to the SQL Extended Set. The optional  |