DuckDB Virtual Server
Perspective provides a built-in virtual server for
DuckDB, allowing <perspective-viewer> to query
DuckDB-WASM databases directly in the browser.
For server-side Python usage, see the Python DuckDB guide.
Installation
npm install @perspective-dev/client @perspective-dev/viewer @duckdb/duckdb-wasm
Usage
Initialize DuckDB-WASM, load data, and connect it to a Perspective viewer:
import perspective from "@perspective-dev/client";
import "@perspective-dev/viewer";
import * as duckdb from "@duckdb/duckdb-wasm";
// Initialize DuckDB-WASM
const DUCKDB_BUNDLES = duckdb.getJsDelivrBundles();
const bundle = await duckdb.selectBundle(DUCKDB_BUNDLES);
const worker = await duckdb.createWorker(bundle.mainWorker);
const logger = new duckdb.ConsoleLogger();
const db = new duckdb.AsyncDuckDB(logger, worker);
await db.instantiate(bundle.mainModule);
// Load data into DuckDB
const conn = await db.connect();
await conn.query(`CREATE TABLE my_table AS SELECT * FROM 'data.parquet'`);
// Create a Perspective virtual server backed by DuckDB
const handler = perspective.DuckDBHandler(db);
const messageHandler = perspective.createMessageHandler(handler);
// Connect a viewer
const client = await perspective.worker(messageHandler);
const table = await client.open_table("my_table");
document.getElementById("viewer").load(table);
Supported features
The DuckDB virtual server supports:
group_by— aggregation via DuckDB’sGROUP BYsplit_by— column pivotingsort— ordering resultsfilter— all standard filter operatorsexpressions— computed columns via DuckDB SQL expressions- Full set of DuckDB aggregate functions (
sum,avg,count,min,max,product,string_agg, etc.)