Submitting multiple SQL statements in a single request¶
This topic explains how to submit a request containing multiple statements to the Snowflake SQL API.
Introduction¶
In some cases, you might need to specify multiple SQL statements in a request. For example, you might need to:
Define an explicit transaction
Set and use session variables in statements in a request
Create and use temporary tables in statements in a request
Change the database, schema, warehouse, or role for statements in a request
The following sections explain how to submit a request that contains multiple SQL statements.
Specifying multiple SQL statements in the request¶
To submit multiple SQL statements in a single request:
In the
statement
field, use a semicolon (;
) between each statement.In the
parameters
field, set theMULTI_STATEMENT_COUNT
field to the number of SQL statements in the request.
For example:
POST /api/v2/statements HTTP/1.1
Authorization: Bearer <jwt>
Content-Type: application/json
Accept: application/json
User-Agent: myApplication/1.0
X-Snowflake-Authorization-Token-Type: KEYPAIR_JWT
{
"statement": "alter session set QUERY_TAG='mytesttag'; select count(*) from mytable",
...
"parameters": {
"MULTI_STATEMENT_COUNT": "2"
}
}
In this example MULTI_STATEMENT_COUNT
is set to 2
which corresponds to the number of SQL statements being submitted.
To submit a variable number of SQL statements in the statement
field, set MULTI_STATEMENT_COUNT
to
0
. This is useful in an application where the number of SQL statements submitted is not known at runtime.
If the value of MULTI_STATEMENT_COUNT
does not match the number of SQL statements specified in the
statement
field, the SQL API returns the following error:
Actual statement count <actual_count> did not match the desired statement count <desired_count>.
Where
actual_count
is the number of statements specified in thestatement
field.desired_count
is the value ofMULTI_STATEMENT_COUNT
.
If you specify multiple SQL statements in the statement
field, but do not specify the
MULTI_STATEMENT_COUNT
field, the SQL API returns the following error:
Actual statement count 3 did not match the desired statement count 1.
Note
Snowflake does not currently support variable binding in multi-statement SQL requests.
Getting the results for each SQL statement in the request¶
If a request that contains multiple SQL statements is processed successfully, the response does not include the data returned from
executing the individual statements. Instead, the response contains a statementHandles
field that contains an array of the
handles for the individual statements.
Note
The statementHandles
field is different from the statementHandle
field:
The
statementHandle
field specifies the handle for the set of SQL statements in the request.The
statementHandles
field is an array of the handles of the individual SQL statements in the request.
For example, suppose that you send a request that specifies two SQL statements for execution:
POST /api/v2/statements HTTP/1.1
Authorization: Bearer <jwt>
Content-Type: application/json
Accept: application/json
User-Agent: myApplication/1.0
X-Snowflake-Authorization-Token-Type: KEYPAIR_JWT
{
"statement": "select * from A; select * from B",
...
}
The response contains a statementHandles
field that contains an array of the handles for the individual statements.
HTTP/1.1 200 OK
...
{
...
"statementHandles" : [ "019c9fce-0502-f1fc-0000-438300e02412", "019c9fce-0502-f1fc-0000-438300e02416" ],
...
}
To check the status and retrieve the data for the individual statements, send a GET
request to the
/api/v2/statements/
endpoint and append the handle for each statement to the URL path. See
Checking the status of the statement execution and retrieving the data for details.
GET /api/v2/statements/019c9fce-0502-f1fc-0000-438300e02412
...
GET /api/v2/statements/019c9fce-0502-f1fc-0000-438300e02416
...
Handling errors when specifying multiple statements in a request¶
If you specified multiple SQL statements in the request and an error occurred when executing any of the statements, Snowflake returns the HTTP response code 422 with a QueryFailureStatus object.
You can get details about the error from this object.
For example, suppose that your request specifies the following statements in which the second INSERT statement contains an error:
{
"statement": "create or replace table table1 (i int); insert into table1 (i) values (1); insert into table1 (i) values ('This is not a valid integer.'); insert into table1 (i) values (2); select i from table1 order by i",
...
}
Snowflake returns a response with the HTTP response code 422 and with a QueryFailureStatus
object that contains the
details about the error:
HTTP/1.1 422 Unprocessable Entity
Content-Type: application/json
...
{
"code" : "100132",
"message" : "JavaScript execution error: Uncaught Execution of multiple statements failed on statement \"insert into table1 (i) values ...\" (at line 1, position 75).\nNumeric value 'This is not a valid integer.' is not recognized in SYSTEM$MULTISTMT at ' throw `Execution of multiple statements failed on statement {0} (at line {1}, position {2}).`.replace('{1}', LINES[i])' position 4\nstackstrace: \nSYSTEM$MULTISTMT line: 10",
"sqlState" : "P0000",
"statementHandle" : "019d6e97-0502-317e-0000-096d0041f036"
}
In the example above, the INSERT statement with the error starts at the character position 75 in the value of the
statement
field.
The statements before the statement with the error are executed successfully (the CREATE TABLE and first INSERT statement in this example). The statements after the statement with the error are not executed.