ABAP Keyword Documentation → ABAP − Reference → Processing External Data → ABAP Database Access → ABAP SQL → ABAP SQL - Write Accesses → INSERT, UPDATE, MODIFY, DELETE - target
INSERT, UPDATE, MODIFY, DELETE dbtab - CLIENT, CLIENTS
Other versions: 
 7.31 | 7.40 | 7.54
Syntax
... { USING CLIENT clnt }  | { CLIENT SPECIFIED } 
 
  | { USING { CLIENT clnt } 
          | { CLIENTS IN @client_range_tab } 
          | { CLIENTS IN T000 } 
          | { ALL CLIENTS } } ... 
Variants
 1. ... {USING CLIENT clnt}|{CLIENT SPECIFIED} 
  2. ... {USING CLIENT clnt}|{USING [ALL] CLIENTS [IN]}   
Effect
These additions modify client
handling of the ABAP SQL write statements INSERT,
UPDATE, 
MODIFY, and DELETE.
They can be specified as optional additions after the target 
target in each of these statements If none of these statements are specified, default client handling applies:
- 
If a work area wa, an internal tableitab, or a subquerysubquery_clausesis specified as a sourcesourceafterFROM, the ID of the current client is used when client-specific tables are modified and not the values of the tables for the client column.
- 
In the case of the variants UPDATE SETorDELETE FROM, in which aWHEREcan be specified, no explicit condition can be applied to the client column. Instead, an implicit condition for the current client is passed to the database system.
The two variants of the optional additions are specific for these two cases:
- 
Variant 1 modifies client handling when sources are specified after FROM.
- 
Variant 2 modifies client handling in modifying statements with potential WHEREconditions.
Notes
- Each client represents a self-contained unit, which means that implicit client handling should not be switched off in application programs.
- 
See also the associated security note and the
programming guideline. 
 
Variant 1
... {USING CLIENT clnt}|{CLIENT SPECIFIED}
 
Alternatives
 1. ... USING CLIENT clnt  
 2. ... CLIENT SPECIFIED   
Effect
These two additions modify implicit 
client handling of a modifying ABAP SQL statement in cases where its source is specified as a work
area wa, internal table itab, or subquery subquery_clauses after FROM.
- 
The addition USING CLIENTswitches implicit client handling to the specified client.
- 
The addition CLIENT SPECIFIEDspecifies that the client IDs specified insourceare used.
Notes
- 
If data is to be edited using precisely one other client ID, USING CLIENTshould be used instead ofCLIENT SPECIFIED, since it specifies the client explicitly.
- 
If data from multiple clients is to be edited, CLIENT SPECIFIEDcan (or must) be used. More specifically, this is the case when an internal table is used as a data source whose client column contains various client IDs or if a subquery is used as a data source to select the data of various clients (usingUSING [ALL] CLIENTS [IN]).
- 
The addition USING [ALL] CLIENTS [IN]cannot be used in this variant.
- 
In this variant, the addition CLIENT SPECIFIEDis not obsolete and is even allowed when accessing global temporary tables. Here, it is used to express the fact that the client IDs of the sources specified afterFROMare used.
Example
The following two INSERT statements produce the same result. The first statement
uses the addition USING CLIENT and hence shows the recommended variant for
specifying the inserted client explicitly. The second statement, on the other hand, uses CLIENT SPECIFIED and must hence fill the client field with the required client in the work area passed.
DELETE FROM demo_expressions USING CLIENT '800'. 
INSERT demo_expressions USING CLIENT '800' 
  FROM @( VALUE #( id = 'X' num1 = '555' ) ). 
DELETE FROM demo_expressions USING CLIENT '800'. 
INSERT demo_expressions CLIENT SPECIFIED 
  FROM @( VALUE #( mandt = '800' id = 'X' num1 = '555' ) ).
Example
Modifies a row in a different client. The first UPDATE statement shows the
recommended method with the addition USING CLIENT. The second UPDATE
statement, on the other hand, uses CLIENT SPECIFIED and the client field of the work area has to be filled.
DELETE FROM demo_update USING ALL CLIENTS. 
INSERT demo_update USING CLIENT '800' 
       FROM @( VALUE #( id = 'X' ) ). 
UPDATE demo_update USING CLIENT '800' 
       FROM @( VALUE #( id = 'X' col1 = 100 ) ). 
UPDATE demo_update CLIENT SPECIFIED 
       FROM @( VALUE #( client = '800' id = 'X' col1 = 100 ) ).
Executable Example
See INSERT, CLIENT  
Alternative 1
... USING CLIENT clnt
 
Effect
This addition modifies implicit 
client handling in ABAP SQL so that the client ID from clnt is used instead of the current client ID. The
ABAP runtime environment
replaces the client specified in source with the client specified in clnt and passes it to the database system.
clnt expects a data object of the type c with length 3 and containing a client ID. A
literal or a host variable can be specified.
The following rules apply to the addition USING:
- It can be used only when modifying a client-specific table or view of this type .
- 
This addition cannot be used with the addition CLIENT SPECIFIED.
- 
It cannot be used if a subquery is used as a data source of 
INSERT or MODIFYin which implicit client handling is switched usingUSING [ALL] CLIENTS [IN].
- 
If specified, the system field sy-mandtwould be ignored and cannot be specified directly forclnt.
Notes
- 
If the addition USING CLIENTis used, the statement ABAP SQL functions as if the current user were logged on with the client ID specified inclnt.
- 
If the addition USING CLIENTis used for a dynamically specified database table or view and they are not client-specific, the addition is ignored.
- 
The addition USING CLIENTis not allowed in the obsolete short forms.
- 
If the addition USING CLIENTis used, the syntax check is performed in a strict mode, which handles the statement more strictly than the regular syntax check.
Example
The following MODIFYstatement uses the addition USING CLIENT, as recommended, to access a specific client.
MODIFY demo_expressions USING CLIENT '800' 
  FROM @( VALUE #( id = 'X' num1 = '555' ) ).
Example
The addition USING CLIENT after INSERT fills two columns of a database table with three rows for the client 100. This rows are then copied to the current client in a
subquery by specifying USING CLIENT.
DELETE FROM demo_expressions. 
DELETE FROM demo_expressions USING CLIENT '100'. 
INSERT demo_expressions USING CLIENT '100' 
  FROM TABLE @( VALUE #( ( id = 'X' num1 = 1 ) 
                        ( id = 'Y' num1 = 2 ) 
                         ( id = 'Z' num1 = 3 ) ) ). 
INSERT demo_expressions FROM 
 ( SELECT * FROM demo_expressions USING CLIENT '100' ) ##NULL_VALUES. 
SELECT id, num1 
       FROM demo_expressions 
       INTO TABLE @DATA(itab). 
SELECT id, num1 
       FROM demo_expressions USING CLIENT '100' 
       INTO TABLE @DATA(itab_100). 
ASSERT itab = itab_100. 
Alternative 2
... CLIENT SPECIFIED
 
Effect
The addition CLIENT SPECIFIED specifies that the
client ID in the
client column in the source source specified after FROM is used and not the ID of the current client.
The following rules apply to the addition CLIENT SPECIFIED:
- It can be used only when accessing client-specific database tables or views .
- 
It cannot be used together with USING CLIENT.
- 
It cannot be used when a subquery is used as a data source of 
INSERT or MODIFYthat works with default client handling or in which implicit client handling is switched usingUSING CLIENT.
- 
It must be used if a subquery is used as a data source of 
INSERT or MODIFYin which implicit client handling is switched usingUSING [ALL] CLIENTS [IN].
Notes
- 
If the addition CLIENT SPECIFIEDis used for a dynamically specified database table or view and they are not client-specific, the addition is ignored.
- 
If specified for statically specified cross-client database tables or views , the addition CLIENT SPECIFIEDproduces a syntax error in the strict modes of the syntax check from Release 7.40, SP05 or else a syntax warning.
Example
This example implements a client copy of all data in a table to multiple clients. The addition 
CLIENT SPECIFIED of the statement INSERT
specifies that the client IDs of the internal table used as a data source are not overwritten by the
current client. The internal table is created in a host variable by copying the data of the current
client read previously from SCARR is copied to multiple different client IDs. Duplicate entries are
avoided by first using the addition USING CLIENTS IN to delete all data of the area in question. After the insertion, all data of this area is read and displayed.
SELECT * 
       FROM scarr 
       INTO TABLE @DATA(itab). 
DATA clients TYPE RANGE OF mandt. 
clients = VALUE #( ( sign = 'I' option = 'GT' low = '900' ) ). 
DELETE FROM scarr USING CLIENTS IN @clients. 
INSERT scarr CLIENT SPECIFIED FROM TABLE @( VALUE #( 
  FOR i = 1 UNTIL i > 4 
  FOR wa IN itab 
       ( VALUE #( BASE wa mandt = 900 + i * 10 ) ) ) ). 
SELECT * 
       FROM scarr USING CLIENTS IN @clients 
       ORDER BY PRIMARY KEY 
       INTO TABLE @DATA(result). 
cl_demo_output=>display( result ). 
Variant 2
... {USING CLIENT clnt}|{USING [ALL] CLIENTS [IN]}
 
Alternatives
 1. ... USING CLIENT clnt  
 2. ... USING CLIENTS IN @client_range_tab  
 3. ... USING CLIENTS IN T000  
 4. ... USING ALL CLIENTS   
Effect
These additions modify implicit 
client handling of a modifying ABAP SQL statement UPDATE
SET or DELETE FROM in which a WHERE condition can be specified.
- 
The addition USING CLIENTswitches implicit client handling to the specified client.
- 
The additions USING [ALL] CLIENTS [IN]select the data of any number of clients instead of the current client.
Note
Instead of USING, the addition CLIENT SPECIFIED can also be specified outside
strict mode from Release 7.54. This is, however, obsolete here. The additions shown here should be used instead.  
Alternative 1
... USING CLIENT clnt
 
Effect
This addition modifies implicit 
client handling in ABAP SQL so that the client ID from clnt is used instead of the current client ID. In the implicit WHERE condition, the
ABAP runtime environment replaces the current client ID by the ID specified in clnt.
clnt expects a data object of the type c with length 3 and containing a client ID. A
literal or a host variable can be specified.
The following rules apply to the addition USING:
- It can be used only when modifying a client-specific table or view of this type .
- 
If specified, the system field sy-mandtwould be ignored and cannot be specified directly forclnt.
Notes
- 
If the addition USING CLIENTis used, the statement ABAP SQL functions as if the current user were logged on with the client ID specified inclnt.
- 
If the addition USING CLIENTis used for a dynamically specified database table or view and they are not client-specific, the addition is ignored.
- 
If the addition USING CLIENTis used, the syntax check is performed in a strict mode, which handles the statement more strictly than the regular syntax check.
 
Example
Statements DELETE FROM with the addition USING CLIENT.
The first statement deletes rows from the client 100 with a specific ID. The second statement deletes all rows of the client 100.
DELETE FROM demo_expressions USING CLIENT '100' WHERE id = 'X'. 
DELETE FROM demo_expressions USING CLIENT '100'. 
Alternative 2
... USING CLIENTS IN @client_range_tab
 
Alternative 3
... USING CLIENTS IN T000
 
Alternative 4
... USING ALL CLIENTS
 
Effect
These additions switch implicit ABAP SQL client handling so that the data of all clients specified by the addition is modified and not just the data from the current client. The additions modify the implicit WHERE condition for the client column passed to the database.
- 
The addition USING CLIENTS IN @client_range_tabselects implicitly the clients whose client IDs meet the conditions in a ranges tableclient_range_tabinstead of the current client. If the ranges table is empty, the data of all clients is selected.
- 
The addition USING CLIENTS IN T000selects implicitly the clients whose client IDs are in the column MANDT of the system table T000 instead of the current client.
- 
The addition USING ALL CLIENTSselects implicitly all rows regardless of client ID instead of the current client.
The same rules apply to the additions as to the identically named additions USING [ALL] CLIENTS [IN] in queries.
Notes
- 
The additions USING [ALL] CLIENTS [IN]replace the obsolete additionCLIENT SPECIFIEDif this is used to select more than one client.
- 
If used, the additions USING [ALL] CLIENTS [IN]apply strict mode from Release 7.54.
Executable Example
See UPDATE, USING CLIENT, CLIENTS