[](https://github.com/rhashimoto/wa-sqlite/actions/workflows/ci.yml)
npm install @dxos/wa-sqlite
IndexedDB and several Origin Private File System virtual file systems are among the examples provided as proof of concept. A table comparing the different VFS classes is here.
Try the demo or run benchmarks with a modern desktop web browser. More information is available in the FAQ, discussion forums, and API reference.
Minor build customization (e.g. changing build defines or flags) can be done with make arguments, and the helper project sqwab can be used to build without a local build environment.
If you do want to build yourself, here are the prerequisites:
* Building on Debian Linux is known to work, compatibility with other platforms is unknown.
* yarn - If you use a different package manager (e.g. npm) then file paths in the demo will need adjustment.
* Emscripten SDK 3.1.61+.
* curl, make, openssl, sed, tclsh, unzip
Here are the build steps:
* Make sure emcc works.
* git clone git@github.com:rhashimoto/wa-sqlite.git
* cd wa-sqlite
* yarn install
* make
The default build produces ES6 modules + WASM, synchronous and asynchronous (using Asyncify and JSPI) in dist/.
``javascript
import SQLiteESMFactory from 'wa-sqlite/dist/wa-sqlite.mjs';
import * as SQLite from 'wa-sqlite';
async function hello() {
const module = await SQLiteESMFactory();
const sqlite3 = SQLite.Factory(module);
const db = await sqlite3.open_v2('myDB');
await sqlite3.exec(db, SELECT 'Hello, world!', (row, columns) => {
console.log(row);
});
await sqlite3.close(db);
}
hello();
`
There is a slightly more complicated example here that also shows how to use a virtual filesystem (VFS) for persistent storage.
The implementation of sqlite3.exec may be of interest to anyone wanting more fine-grained use of SQLite statement objects (e.g. for binding parameters, explicit column datatypes, etc.).
* Open a browser on http://localhost:8000/demo/?build=asyncify&config=IDBBatchAtomicVFS&resetThe demo page provides access to databases on multiple VFS implementations. Query parameters on the demo page URL can be used to specify the configuration and initial state:
| Parameter | Purpose | Values | Default |
|----|----|----|----|
| build | Emscripten build type | default, asyncify, jspi | default |
| config | select VFS | MemoryVFS, MemoryAsyncVFS, IDBBatchAtomicVFS, IDBMirrorVFS, AccessHandlePoolVFS, OPFSAdaptiveVFS, OPFSAnyContextVFS, OPFSCoopSyncVFS, OPFSPermutedVFS | uses SQLite internal memory |
| reset | clear persistent storage | | |
For convenience, if any text region is selected in the editor, only that region will be executed. In addition, the editor contents are restored across page reloads using browser localStorage.
License
MIT License as of February 10, 2023, changed by generous sponsors
Fleet Device Management and Reflect.
Existing licensees may continue under the GPLv3 or switch to the new license.
`
make deps/version-3.50.4/sqlite3.c deps/extension-functions.c WASQLITE_EXTRA_DEFINES="-DSQLITE_ENABLE_FTS5"make WASQLITE_EXTRA_DEFINES="-DSQLITE_ENABLE_FTS5"
``