Use SQLite
Add SQLite as a database with the @primate/sqlite module. Configure it in
config/db; Primate connects to it and provides a unified API.
SQLite is file-based or in-memory, no server needed.
$ npm install @primate/sqlite
TypeScriptconfig/db.ts
import sqlite from "@primate/sqlite";
export default sqlite({
database: "/tmp/app.db", // or ":memory:" for in-memory
});
TypeScriptstores/User.ts
import p from "pema";
import store from "primate/store";
import db from "../config/db.ts";
export default store({
table: "user",
db,
schema: {
id: store.key.primary(p.uuid),
name: p.string,
email: p.string.email(),
},
});
TypeScriptroutes/users.ts
import User from "#store/User";
import route from "primate/route";
export default route({
async get() {
const users = await User.find({});
return users;
},
async post(request) {
const user = await User.insert(await request.body.form());
return user;
},
});