Commit 7592f65
Fix ambiguous errors when statements are cancelled or connection closed (#1291)
## Summary
- When a running query is cancelled (via `Statement.cancel()` or
`Connection.close()`), the driver returned ambiguous errors like
`"error: [null]"` or generic `"Statement execution failed"`
indistinguishable from real connection errors
- **Thrift**: Server returns `CANCELED_STATE` with `OK_STATUS` and null
`errorMessage`. The driver didn't detect `CANCELED_STATE` as a terminal
state, causing downstream failures with null data
- **SEA**: `CANCELED` state fell through to `handleFailedExecution`
which threw `EXECUTE_STATEMENT_FAILED` — same error code as real
failures
- `Connection.close()` called `statement.close()` without cancelling
in-flight queries first, causing running statements to fail with socket
errors
## Changes
1. **Thrift path** (`DatabricksThriftAccessor`): Detect `CANCELED_STATE`
in polling and throw `DatabricksSQLException` with message `"Statement
[id] was cancelled"`, SQL state `HY008`, error code
`EXECUTE_STATEMENT_CANCELLED`
2. **SEA path** (`DatabricksSdkClient`): Detect `CANCELED` state in
`handleFailedExecution` and throw with same clear signal
3. **Connection close** (`DatabricksConnection`): Best-effort `cancel()`
on in-flight statements before closing
4. **Null error message** (`ExecutionStatus`): Default to `"Statement
was cancelled"` when state is ABORTED but error message is null
5. **SQL state constant**: Add `OPERATION_CANCELLED_SQLSTATE = "HY008"`
(standard SQL state for operation cancelled)
## Customer impact
Customers can now programmatically distinguish cancellations from actual
errors by checking:
- SQL state: `HY008` = cancellation
- Error code: `EXECUTE_STATEMENT_CANCELLED`
- Message: `"Statement [id] was cancelled"`
## Test plan
- [x] Full jdbc-core test suite: 3162 tests pass, 0 failures
- [ ] Manual verification: cancel a long-running query and verify the
error message/SQL state
This pull request was AI-assisted by Isaac.
---------
Signed-off-by: Gopal Lal <gopal.lal@databricks.com>
Co-authored-by: Claude Opus 4.6 <noreply@anthropic.com>1 parent 2a76760 commit 7592f65
8 files changed
Lines changed: 143 additions & 1 deletion
File tree
- src
- main/java/com/databricks/jdbc
- api/impl
- common
- dbclient/impl
- sqlexec
- thrift
- test/java/com/databricks/jdbc
- api/impl
- dbclient/impl
- sqlexec
- thrift
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
10 | 10 | | |
11 | 11 | | |
12 | 12 | | |
| 13 | + | |
13 | 14 | | |
14 | 15 | | |
15 | 16 | | |
| |||
Lines changed: 4 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
18 | 18 | | |
19 | 19 | | |
20 | 20 | | |
21 | | - | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
22 | 25 | | |
23 | 26 | | |
24 | 27 | | |
| |||
Lines changed: 4 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
109 | 109 | | |
110 | 110 | | |
111 | 111 | | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
112 | 116 | | |
113 | 117 | | |
114 | 118 | | |
| |||
Lines changed: 12 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
3 | 3 | | |
| 4 | + | |
4 | 5 | | |
5 | 6 | | |
6 | 7 | | |
| |||
709 | 710 | | |
710 | 711 | | |
711 | 712 | | |
| 713 | + | |
| 714 | + | |
| 715 | + | |
| 716 | + | |
| 717 | + | |
| 718 | + | |
| 719 | + | |
| 720 | + | |
| 721 | + | |
| 722 | + | |
| 723 | + | |
712 | 724 | | |
713 | 725 | | |
714 | 726 | | |
| |||
Lines changed: 16 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
| 3 | + | |
3 | 4 | | |
4 | 5 | | |
5 | 6 | | |
| |||
422 | 423 | | |
423 | 424 | | |
424 | 425 | | |
| 426 | + | |
| 427 | + | |
| 428 | + | |
425 | 429 | | |
426 | 430 | | |
427 | 431 | | |
| |||
828 | 832 | | |
829 | 833 | | |
830 | 834 | | |
| 835 | + | |
| 836 | + | |
| 837 | + | |
| 838 | + | |
| 839 | + | |
831 | 840 | | |
832 | 841 | | |
833 | 842 | | |
| |||
863 | 872 | | |
864 | 873 | | |
865 | 874 | | |
| 875 | + | |
| 876 | + | |
| 877 | + | |
| 878 | + | |
| 879 | + | |
| 880 | + | |
| 881 | + | |
866 | 882 | | |
867 | 883 | | |
868 | 884 | | |
| |||
Lines changed: 35 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
Lines changed: 48 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
290 | 290 | | |
291 | 291 | | |
292 | 292 | | |
| 293 | + | |
| 294 | + | |
| 295 | + | |
| 296 | + | |
| 297 | + | |
| 298 | + | |
| 299 | + | |
| 300 | + | |
| 301 | + | |
| 302 | + | |
| 303 | + | |
| 304 | + | |
| 305 | + | |
| 306 | + | |
| 307 | + | |
| 308 | + | |
| 309 | + | |
| 310 | + | |
| 311 | + | |
| 312 | + | |
| 313 | + | |
| 314 | + | |
| 315 | + | |
| 316 | + | |
| 317 | + | |
| 318 | + | |
| 319 | + | |
| 320 | + | |
| 321 | + | |
| 322 | + | |
| 323 | + | |
| 324 | + | |
| 325 | + | |
| 326 | + | |
| 327 | + | |
| 328 | + | |
| 329 | + | |
| 330 | + | |
| 331 | + | |
| 332 | + | |
| 333 | + | |
| 334 | + | |
| 335 | + | |
| 336 | + | |
| 337 | + | |
| 338 | + | |
| 339 | + | |
| 340 | + | |
293 | 341 | | |
294 | 342 | | |
295 | 343 | | |
| |||
Lines changed: 23 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
449 | 449 | | |
450 | 450 | | |
451 | 451 | | |
| 452 | + | |
| 453 | + | |
| 454 | + | |
| 455 | + | |
| 456 | + | |
| 457 | + | |
| 458 | + | |
| 459 | + | |
| 460 | + | |
| 461 | + | |
| 462 | + | |
| 463 | + | |
| 464 | + | |
| 465 | + | |
| 466 | + | |
| 467 | + | |
| 468 | + | |
| 469 | + | |
| 470 | + | |
| 471 | + | |
| 472 | + | |
| 473 | + | |
| 474 | + | |
452 | 475 | | |
453 | 476 | | |
454 | 477 | | |
| |||
0 commit comments