0

Batch SQL queries

by
Published Apr 8, 2025

Run multiple SQL queries across the database branch.

Script xata Verified

The script

Submitted by hugo697 Bun
Verified 428 days ago
1
//native
2
type Xata = {
3
	apiKey: string
4
	workspaceUrl: string
5
}
6
/**
7
 * Batch SQL queries
8
 * Run multiple SQL queries across the database branch.
9
 */
10
export async function main(
11
	auth: Xata,
12
	db_branch_name: string,
13
	body: {
14
		statements: { statement: string; params?: unknown[] }[]
15
		consistency?: 'strong' | 'eventual'
16
		responseType?: 'json' | 'array'
17
	}
18
) {
19
	const url = new URL(`${auth.workspaceUrl}/db/${db_branch_name}/sql/batch`)
20

21
	const response = await fetch(url, {
22
		method: 'POST',
23
		headers: {
24
			'Content-Type': 'application/json',
25
			Authorization: 'Bearer ' + auth.apiKey
26
		},
27
		body: JSON.stringify(body)
28
	})
29
	if (!response.ok) {
30
		const text = await response.text()
31
		throw new Error(`${response.status} ${text}`)
32
	}
33
	return await response.json()
34
}
35