-
1
-
2
-
3
-
4
-
5
-
6
-
7
-
8
-
9
-
10
-
11
-
12
-
13
-
14
-
15
-
16
-
17
-
18
-
19
-
20
-
21
-
22
-
23
-
24
-
25
-
26
-- SPDX-FileCopyrightText: 2025 Shota FUJI <pockawoooh@gmail.com>
-- SPDX-License-Identifier: AGPL-3.0-only
CREATE TABLE events (
seq INTEGER PRIMARY KEY ON CONFLICT ROLLBACK AUTOINCREMENT,
committed_at INTEGER DEFAULT CURRENT_TIMESTAMP,
payload BLOB
);
CREATE TABLE projections (
id INTEGER PRIMARY KEY AUTOINCREMENT,
projection_name TEXT UNIQUE ON CONFLICT ROLLBACK NOT NULL ON CONFLICT ROLLBACK
);
CREATE TABLE snapshots (
id INTEGER PRIMARY KEY AUTOINCREMENT,
event_seq INTEGER NOT NULL ON CONFLICT ROLLBACK,
projection_id INTEGER NOT NULL ON CONFLICT ROLLBACK,
payload BLOB,
FOREIGN KEY(projection_id) REFERENCES projections(id) ON DELETE CASCADE
);
CREATE UNIQUE INDEX workspace_projection_index ON snapshots (
event_seq,
projection_id
);