Reference version

This is documentation for the next SDK version. For up-to-date documentation, see the latest version (SDK 55).

Expo SQLite iconExpo SQLite

一个提供访问可通过 SQLite API 进行查询的数据库的库。

Android
iOS
macOS
tvOS
Web
Included in Expo Go

For the complete documentation index, see llms.txt. Use this Use this file to discover all available pages.

expo-sqlite 让你的应用可以访问一个可通过 SQLite API 查询的数据库。该数据库会在应用重启后持续保留。

警告 在 Apple TV 上,根据 Apple 平台指南,底层数据库文件位于缓存目录,而不是应用文档目录。

安装

Terminal
npx expo install expo-sqlite

If you are installing this in an existing React Native app, make sure to install expo in your project.

在应用配置中进行配置

如果你的项目使用了配置插件(Continuous Native Generation (CNG)),你可以使用其内置的 config pluginexpo-sqlite 配置高级选项。该插件允许你配置一些无法在运行时设置、且必须重新构建新的应用二进制文件才会生效的属性。如果你的应用没有使用 CNG,那么你需要手动配置该库。

Example app.json with config plugin

app.json
{ "expo": { "plugins": [ [ "expo-sqlite", { "enableFTS": true, "useSQLCipher": true, "android": { // 覆盖 Android 的共享配置 "enableFTS": false, "useSQLCipher": false }, "ios": { // 你也可以覆盖 iOS 的共享配置 "customBuildFlags": ["-DSQLITE_ENABLE_DBSTAT_VTAB=1 -DSQLITE_ENABLE_SNAPSHOT=1"] } } ] ] } }

Configurable properties

NameDefaultDescription
customBuildFlags-

传递给 SQLite 构建过程的自定义构建标志。

enableFTStrue

是否启用 FTS3、FTS4FTS5 扩展。

useSQLCipherfalse

使用 SQLCipher 的实现,而不是默认的 SQLite。

useLibSQLfalse

使用 libSQL,而不是默认的 SQLite。

withSQLiteVecExtensionfalse

sqlite-vec 扩展包含到 bundledExtensions 中。

Web 设置

重要 Web 支持处于 alpha 阶段,可能不稳定。如果你遇到任何问题,请 在 GitHub 上创建 issue

要在 web 上使用 expo-sqlite,你需要配置 Metro bundler 以支持 wasm 文件,并添加 HTTP 头以允许使用 SharedArrayBuffer

将以下配置添加到你的 metro.config.js 中。如果你还没有 metro.config.js,可以运行 npx expo customize metro.config.js了解更多

如果你将应用部署到 Web 托管服务,你还需要在 web 服务器上添加 Cross-Origin-Embedder-PolicyCross-Origin-Opener-Policy 头。了解有关 COEPCOOP 头和 SharedArrayBuffer 的更多信息

如果你将应用部署在 EAS Hosting 上,可以在应用配置中配置这些头:

app.json
{ "expo": { "plugins": [ [ "expo-router", { "headers": { "Cross-Origin-Embedder-Policy": "credentialless", "Cross-Origin-Opener-Policy": "same-origin" } } ] ] } }

使用方式

expo-sqlite 导入模块。

Import the module from expo-sqlite
import * as SQLite from 'expo-sqlite';

基本 CRUD 操作

Basic CRUD operations
const db = await SQLite.openDatabaseAsync('databaseName'); // `execAsync()` 适用于需要一次性执行的批量查询。 // 注意 `execAsync()` 不会转义参数,可能导致 SQL 注入。 await db.execAsync(` PRAGMA journal_mode = WAL; CREATE TABLE IF NOT EXISTS test (id INTEGER PRIMARY KEY NOT NULL, value TEXT NOT NULL, intValue INTEGER); INSERT INTO test (value, intValue) VALUES ('test1', 123); INSERT INTO test (value, intValue) VALUES ('test2', 456); INSERT INTO test (value, intValue) VALUES ('test3', 789); `); // `runAsync()` 适用于执行一些写操作。 const result = await db.runAsync('INSERT INTO test (value, intValue) VALUES (?, ?)', 'aaa', 100); console.log(result.lastInsertRowId, result.changes); await db.runAsync('UPDATE test SET intValue = ? WHERE value = ?', 999, 'aaa'); // 从可变参数中绑定无名参数 await db.runAsync('UPDATE test SET intValue = ? WHERE value = ?', [999, 'aaa']); // 从数组中绑定无名参数 await db.runAsync('DELETE FROM test WHERE value = $value', { $value: 'aaa' }); // 从对象中绑定命名参数 // `getFirstAsync()` 适用于从数据库中获取单行结果。 const firstRow = await db.getFirstAsync('SELECT * FROM test'); console.log(firstRow.id, firstRow.value, firstRow.intValue); // `getAllAsync()` 适用于将所有结果作为对象数组获取。 const allRows = await db.getAllAsync('SELECT * FROM test'); for (const row of allRows) { console.log(row.id, row.value, row.intValue); } // `getEachAsync()` 适用于遍历 SQLite 查询游标。 for await (const row of db.getEachAsync('SELECT * FROM test')) { console.log(row.id, row.value, row.intValue); }

预编译语句

预编译语句允许你将 SQL 查询编译一次,然后使用不同参数多次执行。它们会自动转义输入参数以防御 SQL 注入攻击,因此推荐用于包含用户输入的查询。你可以通过在数据库实例上调用 prepareAsync()prepareSync() 方法来获取预编译语句。预编译语句可以通过调用 executeAsync()executeSync() 方法来完成 CRUD 操作。

注意: 记得在使用完语句后调用 finalizeAsync()finalizeSync() 方法来释放预编译语句。推荐使用 try-finally 代码块,以确保预编译语句会被最终释放。

Prepared statements
const statement = await db.prepareAsync( 'INSERT INTO test (value, intValue) VALUES ($value, $intValue)' ); try { let result = await statement.executeAsync({ $value: 'bbb', $intValue: 101 }); console.log('bbb and 101:', result.lastInsertRowId, result.changes); result = await statement.executeAsync({ $value: 'ccc', $intValue: 102 }); console.log('ccc and 102:', result.lastInsertRowId, result.changes); result = await statement.executeAsync({ $value: 'ddd', $intValue: 103 }); console.log('ddd and 103:', result.lastInsertRowId, result.changes); } finally { await statement.finalizeAsync(); } const statement2 = await db.prepareAsync('SELECT * FROM test WHERE intValue >= $intValue'); try { const result = await statement2.executeAsync<{ value: string; intValue: number }>({ $intValue: 100, }); // `getFirstAsync()` 适用于从数据库中获取单行结果。 const firstRow = await result.getFirstAsync(); console.log(firstRow.id, firstRow.value, firstRow.intValue); // 将 SQLite 查询游标重置到开头,以便下一次调用 `getAllAsync()`。 await result.resetAsync(); // `getAllAsync()` 适用于将所有结果作为对象数组获取。 const allRows = await result.getAllAsync(); for (const row of allRows) { console.log(row.value, row.intValue); } // 将 SQLite 查询游标重置到开头,以便下一次 `for-await-of` 循环。 await result.resetAsync(); // 结果对象本身也是一个异步可迭代对象。你可以在 `for-await-of` 循环中使用它来遍历 SQLite 查询游标。 for await (const row of result) { console.log(row.value, row.intValue); } } finally { await statement2.finalizeAsync(); }

标签模板字面量 API

为了方便并提升开发体验,expo-sqlite 通过 db.sql 属性提供了受 Bun 启发的标签模板字面量 API。该 API 会自动转义参数以防止 SQL 注入攻击,并根据查询类型提供自动类型推断。

Tagged template literals API
interface User { id: number; name: string; age: number; } const db = await SQLite.openDatabaseAsync('mydb.db'); const sql = db.sql; const age = 21; const users = await sql<User>`SELECT * FROM users WHERE age > ${age}`; // 类型:User[] console.log(users[0].name); // 可变查询(如 INSERT/UPDATE/DELETE)返回 SQLiteRunResult 元数据 const result = (await sql`INSERT INTO users (name, age) VALUES (${'Alice'}, ${30})`) as SQLite.SQLiteRunResult; console.log(result.lastInsertRowId, result.changes); // 只获取第一行 const user = await sql<User>`SELECT * FROM users WHERE id = ${1}`.first(); if (user) { console.log(user.name); } // 遍历结果 for await (const user of sql<User>`SELECT * FROM users`.each()) { console.log(user.name); } // 同步 API const syncUsers = sql<User>`SELECT * FROM users WHERE age > ${21}`.allSync(); const syncUser = sql<User>`SELECT * FROM users WHERE id = ${1}`.firstSync();

useSQLiteContext() 钩子

useSQLiteContext() hook
import { SQLiteProvider, useSQLiteContext, type SQLiteDatabase } from 'expo-sqlite'; import { useEffect, useState } from 'react'; import { View, Text, StyleSheet } from 'react-native'; export default function App() { return ( <View style={styles.container}> <SQLiteProvider databaseName="test.db" onInit={migrateDbIfNeeded}> <Header /> <Content /> </SQLiteProvider> </View> ); } export function Header() { const db = useSQLiteContext(); const [version, setVersion] = useState(''); useEffect(() => { async function setup() { const result = await db.getFirstAsync<{ 'sqlite_version()': string }>( 'SELECT sqlite_version()' ); setVersion(result['sqlite_version()']); } setup(); }, []); return ( <View style={styles.headerContainer}> <Text style={styles.headerText}>SQLite 版本:{version}</Text> </View> ); } interface Todo { value: string; intValue: number; } export function Content() { const db = useSQLiteContext(); const [todos, setTodos] = useState<Todo[]>([]); useEffect(() => { async function setup() { const result = await db.getAllAsync<Todo>('SELECT * FROM todos'); setTodos(result); } setup(); }, []); return ( <View style={styles.contentContainer}> {todos.map((todo, index) => ( <View style={styles.todoItemContainer} key={index}> <Text>{`${todo.intValue} - ${todo.value}`}</Text> </View> ))} </View> ); } async function migrateDbIfNeeded(db: SQLiteDatabase) { const DATABASE_VERSION = 1; let { user_version: currentDbVersion } = await db.getFirstAsync<{ user_version: number }>( 'PRAGMA user_version' ); if (currentDbVersion >= DATABASE_VERSION) { return; } if (currentDbVersion === 0) { await db.execAsync(` PRAGMA journal_mode = 'wal'; CREATE TABLE todos (id INTEGER PRIMARY KEY NOT NULL, value TEXT NOT NULL, intValue INTEGER); `); await db.runAsync('INSERT INTO todos (value, intValue) VALUES (?, ?)', 'hello', 1); await db.runAsync('INSERT INTO todos (value, intValue) VALUES (?, ?)', 'world', 2); currentDbVersion = 1; } // if (currentDbVersion === 1) { // 添加更多迁移 // } await db.execAsync(`PRAGMA user_version = ${DATABASE_VERSION}`); } const styles = StyleSheet.create({ // 你的样式... });

带有 React.SuspenseuseSQLiteContext() 钩子

useSQLiteContext() 钩子类似,你也可以将 SQLiteProviderReact.Suspense 集成,在数据库准备就绪之前显示一个回退组件。要启用这种集成,请向 SQLiteProvider 组件传入 useSuspense 属性。

useSQLiteContext() hook with React.Suspense
import { SQLiteProvider, useSQLiteContext } from 'expo-sqlite'; import { Suspense } from 'react'; import { View, Text, StyleSheet } from 'react-native'; export default function App() { return ( <View style={styles.container}> <Suspense fallback={<Fallback />}> <SQLiteProvider databaseName="test.db" onInit={migrateDbIfNeeded} useSuspense> <Header /> <Content /> </SQLiteProvider> </Suspense> </View> ); }

在异步事务中执行查询

Executing queries within an async transaction
const db = await SQLite.openDatabaseAsync('databaseName'); await db.withTransactionAsync(async () => { const result = await db.getFirstAsync('SELECT COUNT(*) FROM USERS'); console.log('Count:', result.rows[0]['COUNT(*)']); });

由于 async/await 的特性,只要事务处于活动状态,期间运行的任何查询都会被包含在该事务中。这也包括传入 withTransactionAsync() 的作用域函数之外的查询语句,这可能会让人感到意外。比如,下面的测试用例在传入 withTransactionAsync() 的作用域函数内部和外部都执行了查询。不过,所有查询都会在实际的 SQL 事务中运行,因为第二个 UPDATE 查询在事务结束之前就执行了。

Promise.all([ // 1. 一个新的事务开始 db.withTransactionAsync(async () => { // 2. 值 "first" 被插入到测试表中,然后我们等待 2 // 秒 await db.execAsync('INSERT INTO test (data) VALUES ("first")'); await sleep(2000); // 4. 两秒后,我们从表中读取最新数据 const row = await db.getFirstAsync<{ data: string }>('SELECT data FROM test'); // ❌ 表中的数据将会是 "second",这个断言会失败。 // 另外,这个断言会抛出错误并回滚 // 事务,包括下面的 `UPDATE` 查询,因为它是在 // 事务中运行的。 expect(row.data).toBe('first'); }), // 3. 一秒后,测试表中的数据被更新为 "second"。 // 这个 `UPDATE` 查询虽然代码在事务作用域之外, // 但仍会在事务中运行,因为执行它时事务恰好处于活动状态。 sleep(1000).then(async () => db.execAsync('UPDATE test SET data = "second"')), ]);

withExclusiveTransactionAsync() 函数可以解决这个问题。只有在传入 withExclusiveTransactionAsync() 的作用域函数内运行的查询,才会在实际的 SQL 事务中执行。

执行 PRAGMA 查询

Executing PRAGMA queries
const db = await SQLite.openDatabaseAsync('databaseName'); await db.execAsync('PRAGMA journal_mode = WAL'); await db.execAsync('PRAGMA foreign_keys = ON');

信息 提示: 在创建新数据库时启用 WAL 日志模式,通常可以提升性能。

导入现有数据库

要使用你已经拥有的现有 .db 文件打开一个新的 SQLite 数据库,可以使用 SQLiteProviderassetSource

useSQLiteContext() with existing database
import { SQLiteProvider, useSQLiteContext } from 'expo-sqlite'; import { View, Text, StyleSheet } from 'react-native'; export default function App() { return ( <View style={styles.container}> <SQLiteProvider databaseName="test.db" assetSource={{ assetId: require('./assets/test.db') }}> <Header /> <Content /> </SQLiteProvider> </View> ); }

在应用/扩展之间共享数据库(iOS)

要在同一个 App Group 中与其他应用/扩展共享数据库,你可以按照以下步骤使用共享容器:

1

在应用配置中配置 App Group:

app.json
{ "expo": { "ios": { "bundleIdentifier": "com.myapp", "entitlements": { "com.apple.security.application-groups": ["group.com.myapp"] } } } }

2

使用 expo-file-system 库中的 Paths.appleSharedContainers 来获取共享容器的路径:

Using Shared Container for SQLite Database on iOS
import { SQLiteProvider, defaultDatabaseDirectory } from 'expo-sqlite'; import { Paths } from 'expo-file-system'; import { useMemo } from 'react'; import { Platform, View } from 'react-native'; export default function App() { const dbDirectory = useMemo(() => { if (Platform.OS === 'ios') { return Object.values(Paths.appleSharedContainers)?.[0]?.uri; // 或使用 `Paths.appleSharedContainers['group.com.myapp']?.uri` 来选择特定容器 } return defaultDatabaseDirectory; }, []); return ( <View style={styles.container}> <SQLiteProvider databaseName="test.db" directory={dbDirectory}> <Header /> <Content /> </SQLiteProvider> </View> ); }

传递二进制数据

使用 Uint8Array 向数据库传递二进制数据:

Passing binary data
await db.execAsync(` DROP TABLE IF EXISTS blobs; CREATE TABLE IF NOT EXISTS blobs (id INTEGER PRIMARY KEY NOT NULL, data BLOB); `); const blob = new Uint8Array([0x00, 0x01, 0x02, 0x03, 0x04, 0x05]); await db.runAsync('INSERT INTO blobs (data) VALUES (?)', blob); const row = await db.getFirstAsync<{ data: Uint8Array }>('SELECT * FROM blobs'); expect(row.data).toEqual(blob);

浏览设备上的数据库

expo-sqlite 库包含一个内置的 DevTools 检查器插件,它会在开发环境中自动启用,并且无需额外设置。它允许你浏览表、查看和编辑行、运行 SQL 查询,并直接从浏览器导出数据库。要打开它,请在 Expo CLI 终端中按 shift+m 打开开发工具菜单,然后选择 Open expo-sqlite 来启动检查器。

另外,你也可以使用 drizzle-studio-expo dev tools plugin 直接从 Expo CLI 启动已连接到应用内数据库的 Drizzle Studio。该插件可与任何 expo-sqlite 配置一起使用,并且不需要 Drizzle ORM了解如何安装和使用该插件

键值存储

expo-sqlite 库提供了 Storage,可作为 @react-native-async-storage/async-storage 库的直接替代品。这个键值存储由 SQLite 支持。如果你的项目已经在使用 expo-sqlite,你可以利用 expo-sqlite/kv-store,而无需再添加其他依赖。

Storage 提供与 @react-native-async-storage/async-storage 相同的 API:

Using the Store
// 存储 API 是默认导出,你可以将其命名为 Storage、AsyncStorage 或任何你喜欢的名称。 import Storage from 'expo-sqlite/kv-store'; await Storage.setItem('key', JSON.stringify({ entity: 'value' })); const value = await Storage.getItem('key'); const entity = JSON.parse(value); console.log(entity); // { entity: 'value' }

使用 expo-sqlite/kv-store 的一个主要优势是它还提供同步 API,使用起来更方便:

Using the Store with synchronous APIs
// 存储 API 是默认导出,你可以将其命名为 Storage、AsyncStorage 或任何你喜欢的名称。 import Storage from 'expo-sqlite/kv-store'; Storage.setItemSync('key', 'value'); const value = Storage.getItemSync('key');

如果你当前在项目中使用的是 @react-native-async-storage/async-storage,切换到 expo-sqlite/kv-store 只需要改动导入语句:

- import AsyncStorage from '@react-native-async-storage/async-storage'; + import AsyncStorage from 'expo-sqlite/kv-store';

localStorage API

expo-sqlite/localStorage/install 模块提供了对 localStorage API 的直接实现。如果你已经熟悉 Web 端的这个 API,或者希望能够在 web 和其他平台之间共享存储代码,这会很有用。使用它只需要导入 expo-sqlite/localStorage/install 模块:

注意: import 'expo-sqlite/localStorage/install'; 在 web 上不会产生任何效果,并且会被排除在生产环境的 JS 包之外。

Install globalThis.localStorage
import 'expo-sqlite/localStorage/install'; globalThis.localStorage.setItem('key', 'value'); console.log(globalThis.localStorage.getItem('key')); // 'value'

安全性

SQL 注入是一类漏洞,攻击者会诱使你的应用将用户输入当作 SQL 代码执行。你必须对传递给 SQLite 的所有用户输入进行转义,以防御 SQL 注入。Prepared statements 是解决这个问题的有效防御手段。它们明确地将 SQL 查询的逻辑与输入参数分离,并且 SQLite 在执行 prepared statements 时会自动对输入进行转义。

第三方库集成

expo-sqlite 库旨在成为一个稳定的 SQLite 基础。它支持与第三方库进行更广泛的集成,以实现更高级的上层功能。以下是一些可以与 expo-sqlite 一起使用的库。

Drizzle ORM

Drizzle 是一个 “没有头部的 TypeScript ORM,但又有头部”。它可运行于 Node.js、Bun、Deno 和 React Native。它还提供了一个名为 drizzle-kit 的 CLI 配套工具,用于生成 SQL 迁移。

查看 Drizzle ORM 文档expo-sqlite 集成指南 以了解更多详情。

Knex.js

Knex.js 是一个 SQL 查询构建器,它“灵活、可移植,而且使用起来很有趣!”(expo-sqlite integration guide)

查看 expo-sqlite 集成指南 以了解更多详情。

SQLCipher

注意: Expo Go 不支持 SQLCipher。

SQLCipher 是 SQLite 的一个分支,为数据库增加了加密和认证功能。expo-sqlite 库支持 Android、iOS 和 macOS 上的 SQLCipher。要使用 SQLCipher,你需要按照 app config 中的配置 部分所示,在 app.json 中添加 useSQLCipher 配置,并运行 npx expo prebuild

在你打开数据库之后,需要使用 PRAGMA key = 'password' 语句为数据库设置密码。

给数据库添加密码
const db = await SQLite.openDatabaseAsync('databaseName'); await db.execAsync(`PRAGMA key = 'password'`);

API

常用 API 速查表

下表总结了 SQLiteDatabaseSQLiteStatement 类的常用 API:

SQLiteDatabase 方法SQLiteStatement 方法描述使用场景
runAsync()executeAsync()执行 SQL 查询,并返回所做更改的信息。适用于 SQL 写操作,例如 INSERTUPDATEDELETE
getFirstAsync()executeAsync() + getFirstAsync()获取查询结果中的第一行。适合从数据库中获取单行。例如:getFirstAsync('SELECT * FROM Users WHERE id = ?', userId)
getAllAsync()executeAsync() + getFirstAsync()一次获取所有查询结果。最适合结果集较小的场景,例如带有 LIMIT 子句的查询,如 SELECT * FROM Table LIMIT 100,并且你希望一次性获取所有结果。
getEachAsync()executeAsync() + for-await-of async iterator提供一个用于遍历结果集的迭代器。此方法一次从数据库获取一行,与 getAllAsync() 相比,可能会减少内存使用。推荐用于逐步处理大型结果集,例如无限滚动实现。

Component

SQLiteProvider

Android
iOS
macOS
tvOS
Web

Type: React.Element<NamedExoticComponent<SQLiteProviderProps>>

Context.Provider component that provides a SQLite database to all children. All descendants of this component will be able to access the database using the useSQLiteContext hook.

SQLiteProviderProps

assetSource

Android
iOS
macOS
tvOS
Web
Optional • Type: SQLiteProviderAssetSource

Import a bundled database file from the specified asset module.

Example

assetSource={{ assetId: require('./assets/db.db') }}

children

Android
iOS
macOS
tvOS
Web
Type: ReactNode

The children to render.

databaseName

Android
iOS
macOS
tvOS
Web
Type: string

The name of the database file to open.

directory

Android
iOS
macOS
tvOS
Web
Optional • Type: string • Default: defaultDatabaseDirectory

The directory where the database file is located.

onError

Android
iOS
macOS
tvOS
Web
Optional • Type: (error: Error) => void • Default: rethrow the error

Handle errors from SQLiteProvider.

onInit

Android
iOS
macOS
tvOS
Web
Optional • Type: (db: SQLiteDatabase) => Promise<void>

A custom initialization handler to run before rendering the children. You can use this to run database migrations or other setup tasks.

options

Android
iOS
macOS
tvOS
Web
Optional • Type: SQLiteOpenOptions

Open options.

useSuspense

Android
iOS
macOS
tvOS
Web
Optional • Type: boolean • Default: false

Enable React.Suspense integration.

Example

export default function App() { return ( <Suspense fallback={<Text>Loading...</Text>}> <SQLiteProvider databaseName="test.db" useSuspense={true}> <Main /> </SQLiteProvider> </Suspense> ); }

Constants

SQLite.AsyncStorage

Android
iOS
macOS
tvOS
Web

Type: SQLiteStorage

This default instance of the SQLiteStorage class is used as a drop-in replacement for the AsyncStorage module from @react-native-async-storage/async-storage.

SQLite.bundledExtensions

Android
iOS
macOS
tvOS
Web

Type: Record<string, { entryPoint: string, libPath: string } | undefined>

The pre-bundled SQLite extensions.

SQLite.defaultDatabaseDirectory

Android
iOS
macOS
tvOS
Web

Type: any

The default directory for SQLite databases.

SQLite.Storage

Android
iOS
macOS
tvOS
Web

Type: SQLiteStorage

Alias for AsyncStorage, given the storage not only offers asynchronous methods.

Hooks

useSQLiteContext()

Android
iOS
macOS
tvOS
Web

A global hook for accessing the SQLite database across components. This hook should only be used within a <SQLiteProvider> component.

Example

export default function App() { return ( <SQLiteProvider databaseName="test.db"> <Main /> </SQLiteProvider> ); } export function Main() { const db = useSQLiteContext(); console.log('sqlite version', db.getFirstSync('SELECT sqlite_version()')); return <View /> }

Classes

SQLiteDatabase

Android
iOS
macOS
tvOS
Web

A SQLite database.

SQLiteDatabase Properties

databasePath

Android
iOS
macOS
tvOS
Web
Read Only • Type: string

nativeDatabase

Android
iOS
macOS
tvOS
Web
Read Only • Type: NativeDatabase

options

Android
iOS
macOS
tvOS
Web
Read Only • Type: SQLiteOpenOptions

SQLiteDatabase Methods

closeAsync()

Android
iOS
macOS
tvOS
Web

Close the database.

Returns:
Promise<void>

closeSync()

Android
iOS
macOS
tvOS
Web

Close the database.

Returns:
void

createSessionAsync(dbName)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
dbName(optional)string

The name of the database to create a session for. The default value is main.

Default:'main'

Create a new session for the database.

createSessionSync(dbName)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
dbName(optional)string

The name of the database to create a session for. The default value is main.

Default:'main'

Create a new session for the database.

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

execAsync(source)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
sourcestring

A string containing all the SQL queries.


Execute all SQL queries in the supplied string.

Note: The queries are not escaped for you! Be careful when constructing your queries.

Returns:
Promise<void>

execSync(source)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
sourcestring

A string containing all the SQL queries.


Execute all SQL queries in the supplied string.

Note: The queries are not escaped for you! Be careful when constructing your queries.

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

Returns:
void

getAllAsync(source, params)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
sourcestring

A string containing the SQL query.

paramsSQLiteBindParams

The parameters to bind to the prepared statement. You can pass values in array, object, or variadic arguments. See SQLiteBindValue for more information about binding values.


A convenience wrapper around SQLiteDatabase.prepareAsync(), SQLiteStatement.executeAsync(), SQLiteExecuteAsyncResult.getAllAsync(), and SQLiteStatement.finalizeAsync().

Returns:
Promise<T[]>

Example

// For unnamed parameters, you pass values in an array. db.getAllAsync('SELECT * FROM test WHERE intValue = ? AND name = ?', [1, 'Hello']); // For unnamed parameters, you pass values in variadic arguments. db.getAllAsync('SELECT * FROM test WHERE intValue = ? AND name = ?', 1, 'Hello'); // For named parameters, you should pass values in object. db.getAllAsync('SELECT * FROM test WHERE intValue = $intValue AND name = $name', { $intValue: 1, $name: 'Hello' });

getAllSync(source, params)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
sourcestring

A string containing the SQL query.

paramsSQLiteBindParams

The parameters to bind to the prepared statement. You can pass values in array, object, or variadic arguments. See SQLiteBindValue for more information about binding values.


A convenience wrapper around SQLiteDatabase.prepareSync(), SQLiteStatement.executeSync(), SQLiteExecuteSyncResult.getAllSync(), and SQLiteStatement.finalizeSync().

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

Returns:
T[]

getEachAsync(source, params)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
sourcestring

A string containing the SQL query.

paramsSQLiteBindParams

The parameters to bind to the prepared statement. You can pass values in array, object, or variadic arguments. See SQLiteBindValue for more information about binding values.


A convenience wrapper around SQLiteDatabase.prepareAsync(), SQLiteStatement.executeAsync(), SQLiteExecuteAsyncResult AsyncIterator, and SQLiteStatement.finalizeAsync().

Rather than returning Promise, this function returns an AsyncIterableIterator. You can use for await...of to iterate over the rows from the SQLite query result.

getEachSync(source, params)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
sourcestring

A string containing the SQL query.

paramsSQLiteBindParams

The parameters to bind to the prepared statement. You can pass values in array, object, or variadic arguments. See SQLiteBindValue for more information about binding values.


A convenience wrapper around SQLiteDatabase.prepareSync(), SQLiteStatement.executeSync(), SQLiteExecuteSyncResult Iterator, and SQLiteStatement.finalizeSync().

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

Returns:
IterableIterator<T>

This function returns an IterableIterator. You can use for...of to iterate over the rows from the SQLite query result.

getFirstAsync(source, params)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
sourcestring

A string containing the SQL query.

paramsSQLiteBindParams

The parameters to bind to the prepared statement. You can pass values in array, object, or variadic arguments. See SQLiteBindValue for more information about binding values.


getFirstSync(source, params)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
sourcestring

A string containing the SQL query.

paramsSQLiteBindParams

The parameters to bind to the prepared statement. You can pass values in array, object, or variadic arguments. See SQLiteBindValue for more information about binding values.


A convenience wrapper around SQLiteDatabase.prepareSync(), SQLiteStatement.executeSync(), SQLiteExecuteSyncResult.getFirstSync(), and SQLiteStatement.finalizeSync().

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

Returns:
T | null

isInTransactionAsync()

Android
iOS
macOS
tvOS
Web

Asynchronous call to return whether the database is currently in a transaction.

Returns:
Promise<boolean>

isInTransactionSync()

Android
iOS
macOS
tvOS
Web

Synchronous call to return whether the database is currently in a transaction.

Returns:
boolean

loadExtensionAsync(libPath, entryPoint)

Android
iOS
macOS
tvOS
ParameterTypeDescription
libPathstring

The path to the extension library file.

entryPoint(optional)string

The entry point of the extension. If not provided, the default entry point is inferred by sqlite3_load_extension.


Load a SQLite extension.

Returns:
Promise<void>

Example

// Load `sqlite-vec` from `bundledExtensions`. You need to enable `withSQLiteVecExtension` to include `sqlite-vec`. const extension = SQLite.bundledExtensions['sqlite-vec']; await db.loadExtensionAsync(extension.libPath, extension.entryPoint); // You can also load a custom extension. await db.loadExtensionAsync('/path/to/extension');

loadExtensionSync(libPath, entryPoint)

Android
iOS
macOS
tvOS
ParameterTypeDescription
libPathstring

The path to the extension library file.

entryPoint(optional)string

The entry point of the extension. If not provided, the default entry point is inferred by sqlite3_load_extension.


Load a SQLite extension.

Returns:
void

Example

// Load `sqlite-vec` from `bundledExtensions`. You need to enable `withSQLiteVecExtension` to include `sqlite-vec`. const extension = SQLite.bundledExtensions['sqlite-vec']; db.loadExtensionSync(extension.libPath, extension.entryPoint); // You can also load a custom extension. db.loadExtensionSync('/path/to/extension');

prepareAsync(source)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
sourcestring

A string containing the SQL query.


prepareSync(source)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
sourcestring

A string containing the SQL query.


Create a prepared SQLite statement.

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

runAsync(source, params)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
sourcestring

A string containing the SQL query.

paramsSQLiteBindParams

The parameters to bind to the prepared statement. You can pass values in array, object, or variadic arguments. See SQLiteBindValue for more information about binding values.


runSync(source, params)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
sourcestring

A string containing the SQL query.

paramsSQLiteBindParams

The parameters to bind to the prepared statement. You can pass values in array, object, or variadic arguments. See SQLiteBindValue for more information about binding values.


A convenience wrapper around SQLiteDatabase.prepareSync(), SQLiteStatement.executeSync(), and SQLiteStatement.finalizeSync().

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

serializeAsync(databaseName)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
databaseName(optional)string

The name of the current attached databases. The default value is main which is the default database name.

Default:'main'

Serialize the database as Uint8Array.

Returns:
Promise<Uint8Array<ArrayBufferLike>>

serializeSync(databaseName)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
databaseName(optional)string

The name of the current attached databases. The default value is main which is the default database name.

Default:'main'

Serialize the database as Uint8Array.

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

Returns:
Uint8Array

sql(strings, ...values)

Android
iOS
macOS
tvOS
Web
ParameterType
stringsTemplateStringsArray
...valuesunknown[]

Execute SQL queries using tagged template literals (Bun-style API). Queries are automatically protected against SQL injection using prepared statements.

The query result is directly awaitable and returns an array of objects by default. Use .values(), .first(), or .each() for different result formats.

Example

// Direct await - returns array of objects const users = await sql<User>`SELECT * FROM users WHERE age > ${21}`; // Get first row only const user = await sql<User>`SELECT * FROM users WHERE id = ${userId}`.first(); // Get values as arrays const rows = await sql`SELECT name, age FROM users`.values(); // Returns: [["Alice", 30], ["Bob", 25]] // INSERT/UPDATE/DELETE - returns SQLiteRunResult const result = await sql`INSERT INTO users (name, age) VALUES (${name}, ${age})` as SQLiteRunResult; console.log('Inserted row:', result.lastInsertRowId); // Iteration for await (const user of db<User>`SELECT * FROM users`.each()) { console.log(user.name); } // Synchronous API const users = sql<User>`SELECT * FROM users WHERE age > ${21}`.allSync(); const user = sql<User>`SELECT * FROM users WHERE id = ${userId}`.firstSync();

syncLibSQL()

Android
iOS
macOS
tvOS
Web

Synchronize the local database with the remote libSQL server. This method is only available from libSQL integration.

Returns:
Promise<void>

withExclusiveTransactionAsync(task)

Android
iOS
macOS
tvOS
ParameterTypeDescription
task(txn: Transaction) => Promise<void>

An async function to execute within a transaction. Any queries inside the transaction must be executed on the txn object. The txn object has the same interfaces as the SQLiteDatabase object. You can use txn like a SQLiteDatabase object.


Execute a transaction and automatically commit/rollback based on the task result.

The transaction may be exclusive. As long as the transaction is converted into a write transaction, the other async write queries will abort with database is locked error.

Note: This function is not supported on web.

Returns:
Promise<void>

Example

db.withExclusiveTransactionAsync(async (txn) => { await txn.execAsync('UPDATE test SET name = "aaa"'); });

withTransactionAsync(task)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
task() => Promise<void>

An async function to execute within a transaction.


Execute a transaction and automatically commit/rollback based on the task result.

Note: This transaction is not exclusive and can be interrupted by other async queries.

Returns:
Promise<void>

Example

db.withTransactionAsync(async () => { await db.execAsync('UPDATE test SET name = "aaa"'); // // We cannot control the order of async/await order, so order of execution is not guaranteed. // The following UPDATE query out of transaction may be executed here and break the expectation. // const result = await db.getFirstAsync<{ name: string }>('SELECT name FROM Users'); expect(result?.name).toBe('aaa'); }); db.execAsync('UPDATE test SET name = "bbb"');

If you worry about the order of execution, use withExclusiveTransactionAsync instead.

withTransactionSync(task)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
task() => void

An async function to execute within a transaction.


Execute a transaction and automatically commit/rollback based on the task result.

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

Returns:
void

SQLiteSession

Android
iOS
macOS
tvOS
Web

A class that represents an instance of the SQLite session extension.

SQLiteSession Methods

applyChangesetAsync(changeset)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
changesetChangeset

The changeset to apply.


Apply a changeset asynchronously.

Returns:
Promise<void>

applyChangesetSync(changeset)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
changesetChangeset

The changeset to apply.


Apply a changeset synchronously.

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

Returns:
void

attachAsync(table)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
tablestring | null

The table to attach. If null, all tables are attached.


Attach a table to the session asynchronously.

Returns:
Promise<void>

attachSync(table)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
tablestring | null

The table to attach.


Attach a table to the session synchronously.

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

Returns:
void

closeAsync()

Android
iOS
macOS
tvOS
Web

Close the session asynchronously.

Returns:
Promise<void>

closeSync()

Android
iOS
macOS
tvOS
Web

Close the session synchronously.

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

Returns:
void

createChangesetAsync()

Android
iOS
macOS
tvOS
Web

Create a changeset asynchronously.

createChangesetSync()

Android
iOS
macOS
tvOS
Web

Create a changeset synchronously.

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

Returns:
Changeset

createInvertedChangesetAsync()

Android
iOS
macOS
tvOS
Web

Create an inverted changeset asynchronously. This is a shorthand for createChangesetAsync() + invertChangesetAsync().

createInvertedChangesetSync()

Android
iOS
macOS
tvOS
Web

Create an inverted changeset synchronously. This is a shorthand for createChangesetSync() + invertChangesetSync().

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

Returns:
Changeset

enableAsync(enabled)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
enabledboolean

Whether to enable or disable the session.


Enable or disable the session asynchronously.

Returns:
Promise<void>

enableSync(enabled)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
enabledboolean

Whether to enable or disable the session.


Enable or disable the session synchronously.

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

Returns:
void

invertChangesetAsync(changeset)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
changesetChangeset

The changeset to invert.


Invert a changeset asynchronously.

invertChangesetSync(changeset)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
changesetChangeset

The changeset to invert.


Invert a changeset synchronously.

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

Returns:
Changeset

SQLiteStatement

Android
iOS
macOS
tvOS
Web

A prepared statement returned by SQLiteDatabase.prepareAsync() or SQLiteDatabase.prepareSync() that can be binded with parameters and executed.

SQLiteStatement Methods

executeAsync(params)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
paramsSQLiteBindParams

The parameters to bind to the prepared statement. You can pass values in array, object, or variadic arguments. See SQLiteBindValue for more information about binding values.


Run the prepared statement and return the SQLiteExecuteAsyncResult instance.

executeSync(params)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
paramsSQLiteBindParams

The parameters to bind to the prepared statement. You can pass values in array, object, or variadic arguments. See SQLiteBindValue for more information about binding values.


Run the prepared statement and return the SQLiteExecuteSyncResult instance.

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

finalizeAsync()

Android
iOS
macOS
tvOS
Web

Finalize the prepared statement. This will call the sqlite3_finalize() C function under the hood.

Attempting to access a finalized statement will result in an error.

Note: While expo-sqlite will automatically finalize any orphaned prepared statements upon closing the database, it is considered best practice to manually finalize prepared statements as soon as they are no longer needed. This helps to prevent resource leaks. You can use the try...finally statement to ensure that prepared statements are finalized even if an error occurs.

Returns:
Promise<void>

finalizeSync()

Android
iOS
macOS
tvOS
Web

Finalize the prepared statement. This will call the sqlite3_finalize() C function under the hood.

Attempting to access a finalized statement will result in an error.

Note: While expo-sqlite will automatically finalize any orphaned prepared statements upon closing the database, it is considered best practice to manually finalize prepared statements as soon as they are no longer needed. This helps to prevent resource leaks. You can use the try...finally statement to ensure that prepared statements are finalized even if an error occurs.

Returns:
void

getColumnNamesAsync()

Android
iOS
macOS
tvOS
Web

Get the column names of the prepared statement.

Returns:
Promise<string[]>

getColumnNamesSync()

Android
iOS
macOS
tvOS
Web

Get the column names of the prepared statement.

Returns:
string[]

SQLiteStorage

Android
iOS
macOS
tvOS
Web

Key-value store backed by SQLite. This class accepts a databaseName parameter in its constructor, which is the name of the database file to use for the storage.

SQLiteStorage Methods

clear()

Android
iOS
macOS
tvOS
Web

Alias for clearAsync() method.

Returns:
Promise<void>

clearAsync()

Android
iOS
macOS
tvOS
Web

Clears all key-value pairs from the storage asynchronously.

Returns:
Promise<boolean>

clearSync()

Android
iOS
macOS
tvOS
Web

Clears all key-value pairs from the storage synchronously.

Returns:
boolean

close()

Android
iOS
macOS
tvOS
Web

Alias for closeAsync() method.

Returns:
Promise<void>

closeAsync()

Android
iOS
macOS
tvOS
Web

Closes the database connection asynchronously.

Returns:
Promise<void>

closeSync()

Android
iOS
macOS
tvOS
Web

Closes the database connection synchronously.

Returns:
void

getAllKeys()

Android
iOS
macOS
tvOS
Web

Alias for getAllKeysAsync() method.

Returns:
Promise<string[]>

getAllKeysAsync()

Android
iOS
macOS
tvOS
Web

Retrieves all keys stored in the storage asynchronously.

Returns:
Promise<string[]>

getAllKeysSync()

Android
iOS
macOS
tvOS
Web

Retrieves all keys stored in the storage synchronously.

Returns:
string[]

getItem(key)

Android
iOS
macOS
tvOS
Web
ParameterType
keystring

Alias for getItemAsync() method.

Returns:
Promise<string | null>

getItemAsync(key)

Android
iOS
macOS
tvOS
Web
ParameterType
keystring

Retrieves the value associated with the given key asynchronously.

Returns:
Promise<string | null>

getItemSync(key)

Android
iOS
macOS
tvOS
Web
ParameterType
keystring

Retrieves the value associated with the given key synchronously.

Returns:
string | null

getKeyByIndexAsync(index)

Android
iOS
macOS
tvOS
Web
ParameterType
indexnumber

Retrieves the key at the given index asynchronously.

Returns:
Promise<string | null>

getKeyByIndexSync(index)

Android
iOS
macOS
tvOS
Web
ParameterType
indexnumber

Retrieves the key at the given index synchronously.

Returns:
string | null

getLengthAsync()

Android
iOS
macOS
tvOS
Web

Retrieves the number of key-value pairs stored in the storage asynchronously.

Returns:
Promise<number>

getLengthSync()

Android
iOS
macOS
tvOS
Web

Retrieves the number of key-value pairs stored in the storage synchronously.

Returns:
number

mergeItem(key, value)

Android
iOS
macOS
tvOS
Web
ParameterType
keystring
valuestring

Merges the given value with the existing value for the given key asynchronously. If the existing value is a JSON object, performs a deep merge.

Returns:
Promise<void>

multiGet(keys)

Android
iOS
macOS
tvOS
Web
ParameterType
keysstring[]

Retrieves the values associated with the given keys asynchronously.

Returns:
Promise<undefined>

multiMerge(keyValuePairs)

Android
iOS
macOS
tvOS
Web
ParameterType
keyValuePairsundefined

Merges multiple key-value pairs asynchronously. If existing values are JSON objects, performs a deep merge.

Returns:
Promise<void>

multiRemove(keys)

Android
iOS
macOS
tvOS
Web
ParameterType
keysstring[]

Removes the values associated with the given keys asynchronously.

Returns:
Promise<void>

multiSet(keyValuePairs)

Android
iOS
macOS
tvOS
Web
ParameterType
keyValuePairsundefined

Sets multiple key-value pairs asynchronously.

Returns:
Promise<void>

removeItem(key)

Android
iOS
macOS
tvOS
Web
ParameterType
keystring

Alias for removeItemAsync() method.

Returns:
Promise<void>

removeItemAsync(key)

Android
iOS
macOS
tvOS
Web
ParameterType
keystring

Removes the value associated with the given key asynchronously.

Returns:
Promise<boolean>

removeItemSync(key)

Android
iOS
macOS
tvOS
Web
ParameterType
keystring

Removes the value associated with the given key synchronously.

Returns:
boolean

setItem(key, value)

Android
iOS
macOS
tvOS
Web
ParameterType
keystring
valuestring | SQLiteStorageSetItemUpdateFunction

Alias for setItemAsync().

Returns:
Promise<void>

setItemAsync(key, value)

Android
iOS
macOS
tvOS
Web
ParameterType
keystring
valuestring | SQLiteStorageSetItemUpdateFunction

Sets the value for the given key asynchronously. If a function is provided, it computes the new value based on the previous value.

Returns:
Promise<void>

setItemSync(key, value)

Android
iOS
macOS
tvOS
Web
ParameterType
keystring
valuestring | SQLiteStorageSetItemUpdateFunction

Sets the value for the given key synchronously. If a function is provided, it computes the new value based on the previous value.

Returns:
void

SQLiteTaggedQuery

Android
iOS
macOS
tvOS
Web

Type: Class implements PromiseLike<SQLiteTaggedQueryResult<T>>

A SQL query with tagged template literals API that can be awaited directly (returns array of objects by default), or transformed using .values() or .first() methods.

This API is inspired by Bun's SQL interface:

Example

// Default: returns array of objects const users = await sql`SELECT * FROM users WHERE age > ${21}`; // Get values as arrays const values = await sql`SELECT name, age FROM users`.values(); // Returns: [["Alice", 30], ["Bob", 25]] // Get first row only const user = await sql`SELECT * FROM users WHERE id = ${1}`.first(); // With type parameter const users = await sql<User>`SELECT * FROM users`; // Mutable queries return SQLiteRunResult const result = await sql`INSERT INTO users (name) VALUES (${"Alice"})` as SQLiteRunResult; console.log(result.lastInsertRowId, result.changes); // Synchronous API const users = sql<User>`SELECT * FROM users WHERE age > ${21}`.allSync(); const user = sql<User>`SELECT * FROM users WHERE id = ${userId}`.firstSync();

SQLiteTaggedQuery Methods

allSync()

Android
iOS
macOS
tvOS
Web

Execute a query synchronously that returns rows or metadata based on query type.

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

Returns:
SQLiteTaggedQueryResult<T>

each()

Android
iOS
macOS
tvOS
Web

Execute the query and return an async iterator over the rows.

Example

for await (const user of sql`SELECT * FROM users`.each()) { console.log(user.name); }

eachSync()

Android
iOS
macOS
tvOS
Web

Execute the query synchronously and return an iterator.

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

Returns:
IterableIterator<T>

first()

Android
iOS
macOS
tvOS
Web

Execute the query and return the first row only. Returns null if no rows match.

Returns:
Promise<T | null>

Example

const user = await sql`SELECT * FROM users WHERE id = ${1}`.first();

firstSync()

Android
iOS
macOS
tvOS
Web

Execute the query synchronously and return the first row.

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

Returns:
T | null

values()

Android
iOS
macOS
tvOS
Web

Execute the query and return rows as arrays of values (Bun-style). Each row is an array where values are in column order.

Returns:
Promise<any[][]>

Example

const rows = await sql`SELECT name, age FROM users`.values(); // Returns: [["Alice", 30], ["Bob", 25]]

valuesSync()

Android
iOS
macOS
tvOS
Web

Execute the query synchronously and return rows as arrays of values.

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

Returns:
any[][]

Methods

SQLite.backupDatabaseAsync(options)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
options{ destDatabase: SQLiteDatabase, destDatabaseName: string, sourceDatabase: SQLiteDatabase, sourceDatabaseName: string }

The backup options


Backup a database to another database.

Returns:
Promise<void>

SQLite.backupDatabaseSync(options)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
options{ destDatabase: SQLiteDatabase, destDatabaseName: string, sourceDatabase: SQLiteDatabase, sourceDatabaseName: string }

The backup options


Backup a database to another database.

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

Returns:
void

SQLite.deepEqual(a, b)

Android
iOS
macOS
tvOS
Web
ParameterType
aundefined | undefined
bundefined | undefined

Compares two objects deeply for equality.

Returns:
boolean

SQLite.deleteDatabaseAsync(databaseName, directory)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
databaseNamestring

The name of the database file to delete.

directory(optional)string

The directory where the database file is located. The default value is defaultDatabaseDirectory.


Delete a database file.

Returns:
Promise<void>

SQLite.deleteDatabaseSync(databaseName, directory)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
databaseNamestring

The name of the database file to delete.

directory(optional)string

The directory where the database file is located. The default value is defaultDatabaseDirectory.


Delete a database file.

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

Returns:
void

SQLite.deserializeDatabaseAsync(serializedData, options)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
serializedDataUint8Array

The binary array to deserialize from SQLiteDatabase.serializeAsync().

options(optional)SQLiteOpenOptions

Open options.


Given a Uint8Array data and deserialize to memory database.

SQLite.deserializeDatabaseSync(serializedData, options)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
serializedDataUint8Array

The binary array to deserialize from SQLiteDatabase.serializeSync()

options(optional)SQLiteOpenOptions

Open options.


Given a Uint8Array data and deserialize to memory database.

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

SQLite.openDatabaseAsync(databaseName, options, directory)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
databaseNamestring

The name of the database file to open.

options(optional)SQLiteOpenOptions

Open options.

directory(optional)string

The directory where the database file is located. The default value is defaultDatabaseDirectory. This parameter is not supported on web.


Open a database.

SQLite.openDatabaseSync(databaseName, options, directory)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
databaseNamestring

The name of the database file to open.

options(optional)SQLiteOpenOptions

Open options.

directory(optional)string

The directory where the database file is located. The default value is defaultDatabaseDirectory. This parameter is not supported on web.


Open a database.

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

Event Subscriptions

SQLite.addDatabaseChangeListener(listener)

Android
iOS
macOS
tvOS
Web
ParameterTypeDescription
listener(event: DatabaseChangeEvent) => void

A function that receives the databaseName, databaseFilePath, tableName and rowId of the modified data.


Add a listener for database changes.

Note: to enable this feature, you must set enableChangeListener to true when opening the database.

Returns:
EventSubscription

A Subscription object that you can call remove() on when you would like to unsubscribe the listener.

Interfaces

SQLiteExecuteAsyncResult

Android
iOS
macOS
tvOS
Web

Extends: AsyncIterableIterator<T>

A result returned by SQLiteStatement.executeAsync().

Example

The result includes the lastInsertRowId and changes properties. You can get the information from the write operations.

const statement = await db.prepareAsync('INSERT INTO test (value) VALUES (?)'); try { const result = await statement.executeAsync(101); console.log('lastInsertRowId:', result.lastInsertRowId); console.log('changes:', result.changes); } finally { await statement.finalizeAsync(); }

Example

The result implements the AsyncIterator interface, so you can use it in for await...of loops.

const statement = await db.prepareAsync('SELECT value FROM test WHERE value > ?'); try { const result = await statement.executeAsync<{ value: number }>(100); for await (const row of result) { console.log('row value:', row.value); } } finally { await statement.finalizeAsync(); }

Example

If your write operations also return values, you can mix all of them together.

const statement = await db.prepareAsync('INSERT INTO test (name, value) VALUES (?, ?) RETURNING name'); try { const result = await statement.executeAsync<{ name: string }>('John Doe', 101); console.log('lastInsertRowId:', result.lastInsertRowId); console.log('changes:', result.changes); for await (const row of result) { console.log('name:', row.name); } } finally { await statement.finalizeAsync(); }
PropertyTypeDescription
changesnumber

The number of rows affected. Returned from the sqlite3_changes() function.

lastInsertRowIdnumber

The last inserted row ID. Returned from the sqlite3_last_insert_rowid() function.

SQLiteExecuteAsyncResult Methods

getAllAsync()

Android
iOS
macOS
tvOS
Web

Get all rows of the result set. This requires the SQLite cursor to be in its initial state. If you have already retrieved rows from the result set, you need to reset the cursor first by calling resetAsync(). Otherwise, an error will be thrown.

Returns:
Promise<T[]>

getFirstAsync()

Android
iOS
macOS
tvOS
Web

Get the first row of the result set. This requires the SQLite cursor to be in its initial state. If you have already retrieved rows from the result set, you need to reset the cursor first by calling resetAsync(). Otherwise, an error will be thrown.

Returns:
Promise<T | null>

resetAsync()

Android
iOS
macOS
tvOS
Web

Reset the prepared statement cursor. This will call the sqlite3_reset() C function under the hood.

Returns:
Promise<void>

SQLiteExecuteSyncResult

Android
iOS
macOS
tvOS
Web

Extends: IterableIterator<T>

A result returned by SQLiteStatement.executeSync().

Note: Running heavy tasks with this function can block the JavaScript thread and affect performance.

Example

The result includes the lastInsertRowId and changes properties. You can get the information from the write operations.

const statement = db.prepareSync('INSERT INTO test (value) VALUES (?)'); try { const result = statement.executeSync(101); console.log('lastInsertRowId:', result.lastInsertRowId); console.log('changes:', result.changes); } finally { statement.finalizeSync(); }

Example

The result implements the Iterator interface, so you can use it in for...of loops.

const statement = db.prepareSync('SELECT value FROM test WHERE value > ?'); try { const result = statement.executeSync<{ value: number }>(100); for (const row of result) { console.log('row value:', row.value); } } finally { statement.finalizeSync(); }

Example

If your write operations also return values, you can mix all of them together.

const statement = db.prepareSync('INSERT INTO test (name, value) VALUES (?, ?) RETURNING name'); try { const result = statement.executeSync<{ name: string }>('John Doe', 101); console.log('lastInsertRowId:', result.lastInsertRowId); console.log('changes:', result.changes); for (const row of result) { console.log('name:', row.name); } } finally { statement.finalizeSync(); }
PropertyTypeDescription
changesnumber

The number of rows affected. Returned from the sqlite3_changes() function.

lastInsertRowIdnumber

The last inserted row ID. Returned from the sqlite3_last_insert_rowid() function.

SQLiteExecuteSyncResult Methods

getAllSync()

Android
iOS
macOS
tvOS
Web

Get all rows of the result set. This requires the SQLite cursor to be in its initial state. If you have already retrieved rows from the result set, you need to reset the cursor first by calling resetSync(). Otherwise, an error will be thrown.

Returns:
T[]

getFirstSync()

Android
iOS
macOS
tvOS
Web

Get the first row of the result set. This requires the SQLite cursor to be in its initial state. If you have already retrieved rows from the result set, you need to reset the cursor first by calling resetSync(). Otherwise, an error will be thrown.

Returns:
T | null

resetSync()

Android
iOS
macOS
tvOS
Web

Reset the prepared statement cursor. This will call the sqlite3_reset() C function under the hood.

Returns:
void

SQLiteOpenOptions

Android
iOS
macOS
tvOS
Web

Options for opening a database.

PropertyTypeDescription
enableChangeListener(optional)boolean

Whether to call the sqlite3_update_hook() function and enable the onDatabaseChange events. You can later subscribe to the change events by addDatabaseChangeListener.

Default:false
libSQLOptions(optional){ authToken: string, remoteOnly: boolean, url: string }

Options for libSQL integration.

useNewConnection(optional)boolean

Whether to create new connection even if connection with the same database name exists in cache.

Default:false

SQLiteProviderAssetSource

Android
iOS
macOS
tvOS
Web
PropertyTypeDescription
assetIdnumber

The asset ID returned from the require() call.

forceOverwrite(optional)boolean

Force overwrite the local database file even if it already exists.

Default:false

SQLiteRunResult

Android
iOS
macOS
tvOS
Web
PropertyTypeDescription
changesnumber

The number of rows affected. Returned from the sqlite3_changes() function.

lastInsertRowIdnumber

The last inserted row ID. Returned from the sqlite3_last_insert_rowid() function.

Types

Changeset

Android
iOS
macOS
tvOS
Web

Type: Uint8Array

A type that represents a changeset.

DatabaseChangeEvent

Android
iOS
macOS
tvOS
Web

The event payload for the listener of addDatabaseChangeListener

PropertyTypeDescription
databaseFilePathstring

The absolute file path to the database.

databaseNamestring

The database name. The value would be main by default and other database names if you use ATTACH DATABASE statement.

rowIdnumber

The changed row ID.

tableNamestring

The table name.

SQLiteBindParams

Android
iOS
macOS
tvOS
Web

Literal Type: Record

Acceptable values are: Record<string, SQLiteBindValue>

SQLiteBindValue

Android
iOS
macOS
tvOS
Web

Literal Type: union

Bind parameters to the prepared statement. You can either pass the parameters in the following forms:

Example

A single array for unnamed parameters.

const statement = await db.prepareAsync('SELECT * FROM test WHERE value = ? AND intValue = ?'); const result = await statement.executeAsync(['test1', 789]); const firstRow = await result.getFirstAsync();

Example

Variadic arguments for unnamed parameters.

const statement = await db.prepareAsync('SELECT * FROM test WHERE value = ? AND intValue = ?'); const result = await statement.executeAsync('test1', 789); const firstRow = await result.getFirstAsync();

Example

A single object for named parameters

We support multiple named parameter forms such as :VVV, @VVV, and $VVV. We recommend using $VVV because JavaScript allows using $ in identifiers without escaping.

const statement = await db.prepareAsync('SELECT * FROM test WHERE value = $value AND intValue = $intValue'); const result = await statement.executeAsync({ $value: 'test1', $intValue: 789 }); const firstRow = await result.getFirstAsync();

Acceptable values are: string | number | null | boolean | Uint8Array

SQLiteStorageSetItemUpdateFunction(prevValue)

Android
iOS
macOS
tvOS
Web

Update function for the setItemAsync() or setItemSync() method. It computes the new value based on the previous value. The function returns the new value to set for the key.

ParameterTypeDescription
prevValuestring | null

The previous value associated with the key, or null if the key was not set.

Returns:

string

SQLiteVariadicBindParams

Android
iOS
macOS
tvOS
Web

Type: SQLiteBindValue[]