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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
//! Query execution routes
//!
//! Provides REST endpoints for executing SQL queries and statements.
use ;
use crate;
/// Create query execution routes
///
/// # Endpoints
///
/// - `POST /v1/branches/:name/query` - Execute read-only SQL query
/// - `POST /v1/branches/:name/execute` - Execute DDL/DML statement
///
/// # Query Endpoint (POST /v1/branches/:name/query)
///
/// Executes a SELECT query and returns results. Supports:
/// - Parameterized queries ($1, $2, etc.)
/// - Time-travel queries (AS OF)
/// - Query timeout configuration
///
/// **Request Body:**
/// ```json
/// {
/// "sql": "SELECT * FROM users WHERE id = $1",
/// "params": [{"type": "int4", "value": 1}],
/// "as_of": {"type": "timestamp", "value": 1234567890},
/// "timeout_ms": 5000
/// }
/// ```
///
/// **Response:**
/// ```json
/// {
/// "columns": ["id", "name", "email"],
/// "column_types": ["int4", "text", "text"],
/// "rows": [
/// {"id": 1, "name": "Alice", "email": "alice@example.com"}
/// ],
/// "row_count": 1,
/// "execution_time_ms": 42
/// }
/// ```
///
/// # Execute Endpoint (POST /v1/branches/:name/execute)
///
/// Executes DDL/DML statements (INSERT, UPDATE, DELETE, CREATE TABLE, etc.).
///
/// **Request Body:**
/// ```json
/// {
/// "sql": "INSERT INTO users (id, name) VALUES ($1, $2)",
/// "params": [
/// {"type": "int4", "value": 1},
/// {"type": "string", "value": "Alice"}
/// ],
/// "timeout_ms": 5000
/// }
/// ```
///
/// **Response:**
/// ```json
/// {
/// "statement_type": "INSERT",
/// "affected_rows": 1,
/// "execution_time_ms": 23,
/// "message": "INSERT statement executed successfully on branch 'main'"
/// }
/// ```