0.8.28 • Published 5 days ago

@canvas-js/modeldb v0.8.28

Weekly downloads
-
License
-
Repository
-
Last release
5 days ago

@canvas-js/modeldb

ModelDB is a minimalist cross-platform relational database wrapper. It currently supports IndexedDB (browser) and SQLite (NodeJS) backends.

Table of Contents

Usage

Initialization

Import ModelDB from either @canvas-js/modeldb/idb (browser) or @canvas-js/modeldb/sqlite (NodeJS).

import { ModelDB } from "@canvas-js/modeldb/sqlite"

const db = await ModelDB.init({
  path: "/path/to/db.sqlite", // set `path: null` for an in-memory database
  models: { ... }
})
import { ModelDB } from "@canvas-js/modeldb/idb"

const db = await ModelDB.init({
  name: "my-database-name", // used as the IndexedDB database name
  models: { ... }
})

Schemas

Databases are configured with a models schema, provided as a JSON DSL. Every model has a mandatory string primary key and supports nullable and non-nullable integer, float, string and bytes datatypes. It also supports a non-nullable json datatype.

const db = await ModelDB.init({
  models: {
    user: {
      // exactly one "primary" property is required
      id: "primary",
      // properties are non-null by default
      name: "string",
      // declare nullable properties using `?`
      birthday: "string?",
      // json data is also supported
      metadata: "json",
    },
  },
})

await db.set("user", { id: "xxx", name: "John", birthday: "1990-01-01", metadata: {} })
await db.set("user", { id: "xxx", name: "John Doe", birthday: "1990-01-01", metadata: { home: "New York" } })
await db.get("user", "xxx") // { id: "xxx", name: "John Doe", birthday: "1990-01-01", metadata: { home: "New York" } }

Reference properties (@user with string values), nullable reference properties (@user? with string | null values), and relation properties (@user[] with string[] values) are also supported, although the foreign key constraint is not enforced.

const db = await ModelDB.init({
  models: {
    user: {
      user_id: "primary",
      name: "string",
    },
    room: {
      room_id: "primary",
      members: "@user[]",
    },
    message: {
      message_id: "primary",
      user: "@user",
      content: "string",
      timestamp: "integer",
    },
  },
})

Setting and deleting records

Mutate the database using either the set and delete methods, or the lower-level apply method to batch operations in an atomic transaction:

await db.set("user", { user_id: "xxx", name: "John Doe" })
await db.set("user", { user_id: "yyy", name: "Jane Doe" })
await db.delete("user", "xxx")

await db.apply([
  { model: "user", operation: "set", value: { user_id: "xxx", name: "John Doe" } },
  { model: "user", operation: "set", value: { user_id: "yyy", name: "Jane Doe" } },
  { model: "user", operation: "delete", key: "xxx" },
])

Queries

Access data using the query method, or use the get to retrieve records by primary key.

await db.set("user", { user_id: "a", name: "Alice" })
await db.set("user", { user_id: "b", name: "Bob" })
await db.set("user", { user_id: "c", name: "Carol" })

await db.get("user", "a") // { user_id: "a", name: "Alice" }
await db.get("user", "d") // null

await db.query("user", { where: { user_id: { gte: "b" } } })
// [
//   { user_id: "b", name: "Bob" },
//   { user_id: "c", name: "Carol" },
// ]

Queries support select, where, orderBy, and limit expressions. where conditions can have equality, inequality, and range terms.

export type QueryParams = {
  select?: Record<string, boolean>
  where?: WhereCondition
  orderBy?: Record<string, "asc" | "desc">
  limit?: number
  offset?: number
}

export type WhereCondition = Record<string, PropertyValue | NotExpression | RangeExpression>
export type NotExpression = {
  neq: PropertyValue
}

export type RangeExpression = {
  gt?: PrimitiveValue
  gte?: PrimitiveValue
  lt?: PrimitiveValue
  lte?: PrimitiveValue
}

Indexes

By default, queries translate into filters applied to a full table scan. You can create indexes using the special $indexes: string[] property:

const db = await ModelDB.init({
  models: {
    ...
    message: {
      message_id: "primary",
      user: "@user",
      content: "string",
      timestamp: "integer",
      $indexes: ["timestamp"]
    },
  },
})

// this will use the `timestamp` index to avoid a full table scan
const recentMessages = await db.query("message", { orderBy: { timestamp: "desc" }, limit: 10 })

Multi-property index support will be added soon.

Name restrictions

Model names and property names can contain [a-zA-Z0-9$:_\-\.].

License

MIT © 2023 Canvas Technologies, Inc.

0.8.28

5 days ago

0.8.27-patch.21

7 days ago

0.8.27-patch.14

19 days ago

0.8.27-patch.13

19 days ago

0.8.27-patch.16

19 days ago

0.8.27-patch.15

19 days ago

0.8.27-patch.10

19 days ago

0.8.27-patch.6

20 days ago

0.8.27-patch.7

19 days ago

0.8.27-patch.12

19 days ago

0.8.27-patch.8

19 days ago

0.8.27-patch.11

19 days ago

0.8.27-patch.9

19 days ago

0.8.27-patch.20

18 days ago

0.9.1

20 days ago

0.8.27-patch.18

18 days ago

0.8.27-patch.17

18 days ago

0.8.27-patch.19

18 days ago

0.8.27-patch.2

23 days ago

0.8.27-patch.3

23 days ago

0.8.27-patch.4

23 days ago

0.8.27-patch.5

23 days ago

0.8.27-patch.1

23 days ago

0.9.0

27 days ago

0.9.0-next.1

1 month ago

0.8.26-alpha.4

4 months ago

0.8.26-alpha.3

4 months ago

0.8.26-alpha.2

4 months ago

0.8.26

4 months ago

0.8.26-alpha.1

4 months ago

0.8.25

4 months ago

0.8.24

4 months ago

0.8.23

4 months ago

0.8.22

4 months ago

0.8.21

5 months ago

0.8.20

5 months ago

0.8.19

5 months ago

0.8.18

5 months ago

0.8.17

5 months ago

0.8.16

5 months ago

0.8.15

5 months ago

0.8.14-alpha.1

5 months ago

0.8.14

5 months ago

0.8.13

6 months ago

0.8.12

6 months ago

0.8.11

6 months ago

0.8.10

6 months ago

0.8.9

6 months ago

0.8.8

6 months ago

0.8.5

6 months ago

0.8.4

6 months ago

0.8.7

6 months ago

0.8.6

6 months ago

0.8.2-alpha.1

6 months ago

0.8.2-patch.1

6 months ago

0.8.3

6 months ago

0.8.2

6 months ago

0.7.2-alpha.1

6 months ago

0.7.2-alpha.2

6 months ago

0.7.2-alpha.3

6 months ago

0.7.2-alpha.4

6 months ago

0.7.2-alpha.5

6 months ago

0.7.2-alpha.6

6 months ago

0.7.2-alpha.7

6 months ago

0.8.1

6 months ago

0.7.2

6 months ago

0.8.0

6 months ago

0.7.1

6 months ago

0.7.3

6 months ago

0.7.0

6 months ago

0.6.1

6 months ago

0.6.0

6 months ago

0.5.1

7 months ago

0.5.0

7 months ago

0.6.0-alpha7

7 months ago

0.6.0-alpha6

8 months ago

0.6.0-alpha5

8 months ago

0.6.0-alpha4

8 months ago

0.6.0-alpha3

8 months ago

0.6.0-alpha2

8 months ago