exarrow-rs 0.8.0

ADBC-compatible driver for Exasol with Arrow data format support
Documentation
# Feature: Execution

Specifies SQL query execution capabilities including direct queries, prepared statements, batch execution, and query cancellation through connection-owned transport.

## Background

All SQL execution occurs through Connection-owned transport via the WebSocket protocol. The system supports direct query execution (SELECT, DDL, DML), prepared statements with parameter binding, batch execution of multiple queries, and cancellation of in-flight queries. Results are returned as Arrow RecordBatch. Execution goes through Connection methods such as `execute_statement()`, `execute_statement_update()`, `prepare()`, and `execute_prepared()`.

## Scenarios

### Scenario: Simple SELECT query

* *GIVEN* an authenticated connection exists to Exasol
* *WHEN* executing a simple SELECT statement via `Connection::execute_statement()`
* *THEN* it SHALL send the query to Exasol via WebSocket
* *AND* it SHALL retrieve the complete result set
* *AND* it SHALL return results as Arrow RecordBatch

### Scenario: DDL statement execution

* *GIVEN* an authenticated connection exists to Exasol
* *WHEN* executing DDL statements (CREATE, ALTER, DROP) via `Connection::execute_statement()`
* *THEN* it SHALL execute the statement
* *AND* it SHALL return success or error status
* *AND* it SHALL return affected object information

### Scenario: DML statement execution

* *GIVEN* an authenticated connection exists to Exasol
* *WHEN* executing DML statements (INSERT, UPDATE, DELETE) via `Connection::execute_statement_update()`
* *THEN* it SHALL execute the statement
* *AND* it SHALL return the number of affected rows

### Scenario: Statement preparation

* *GIVEN* an authenticated connection exists to Exasol
* *WHEN* preparing a SQL statement via `Connection::prepare()`
* *THEN* it SHALL validate the SQL syntax
* *AND* it SHALL identify parameter placeholders
* *AND* it SHALL return a PreparedStatement handle

### Scenario: Parameter binding

* *GIVEN* a prepared statement has been created
* *WHEN* binding parameters to a PreparedStatement
* *THEN* it SHALL validate parameter types against expected types
* *AND* it SHALL convert Rust types to Exasol-compatible values
* *AND* it SHALL prevent SQL injection through proper escaping

### Scenario: Prepared statement execution

* *GIVEN* a prepared statement has been created
* *WHEN* executing a PreparedStatement via `Connection::execute_prepared()`
* *THEN* it SHALL substitute parameters safely
* *AND* it SHALL execute the query
* *AND* it SHALL return results in Arrow format

### Scenario: Sequential query execution

* *GIVEN* multiple queries are ready for execution
* *WHEN* multiple queries are submitted for execution
* *THEN* it SHALL execute them in order
* *AND* it SHALL return results for each query separately
* *AND* it SHALL stop on first error if specified

### Scenario: Independent query execution

* *GIVEN* multiple queries are ready for execution
* *WHEN* queries are marked as independent
* *THEN* it SHALL execute all queries regardless of individual failures
* *AND* it SHALL collect results and errors for each query

### Scenario: Cancel running query

* *GIVEN* a long-running query is executing
* *WHEN* a query is cancelled during execution
* *THEN* it SHALL send a cancellation request to Exasol
* *AND* it SHALL wait for cancellation acknowledgment or timeout
* *AND* it SHALL return a cancellation error

### Scenario: Cancel with timeout

* *GIVEN* a long-running query is executing
* *WHEN* cancellation takes longer than timeout
* *THEN* it SHALL forcefully abort the local query execution
* *AND* it SHALL close the connection if necessary