memos/store/db/migration/dev/LATEST__SCHEMA.sql

90 lines
2.8 KiB
MySQL
Raw Normal View History

2022-11-19 09:57:54 +08:00
-- migration_history
CREATE TABLE migration_history (
version TEXT NOT NULL PRIMARY KEY,
created_ts BIGINT NOT NULL DEFAULT (strftime('%s', 'now'))
);
-- system_setting
CREATE TABLE system_setting (
name TEXT NOT NULL,
value TEXT NOT NULL,
description TEXT NOT NULL DEFAULT '',
UNIQUE(name)
);
2022-02-03 15:32:03 +08:00
-- user
CREATE TABLE user (
id INTEGER PRIMARY KEY AUTOINCREMENT,
2022-05-17 21:21:13 +08:00
created_ts BIGINT NOT NULL DEFAULT (strftime('%s', 'now')),
updated_ts BIGINT NOT NULL DEFAULT (strftime('%s', 'now')),
2022-05-19 18:32:04 +08:00
row_status TEXT NOT NULL CHECK (row_status IN ('NORMAL', 'ARCHIVED')) DEFAULT 'NORMAL',
username TEXT NOT NULL UNIQUE,
role TEXT NOT NULL CHECK (role IN ('HOST', 'ADMIN', 'USER')) DEFAULT 'USER',
email TEXT NOT NULL DEFAULT '',
nickname TEXT NOT NULL DEFAULT '',
2022-02-06 16:19:20 +08:00
password_hash TEXT NOT NULL,
2022-05-17 21:21:13 +08:00
open_id TEXT NOT NULL UNIQUE
2022-02-03 15:32:03 +08:00
);
2022-11-19 09:57:54 +08:00
-- user_setting
CREATE TABLE user_setting (
user_id INTEGER NOT NULL,
key TEXT NOT NULL,
value TEXT NOT NULL,
UNIQUE(user_id, key)
);
2022-02-03 15:32:03 +08:00
-- memo
CREATE TABLE memo (
id INTEGER PRIMARY KEY AUTOINCREMENT,
2022-05-17 21:21:13 +08:00
creator_id INTEGER NOT NULL,
2022-02-03 15:32:03 +08:00
created_ts BIGINT NOT NULL DEFAULT (strftime('%s', 'now')),
updated_ts BIGINT NOT NULL DEFAULT (strftime('%s', 'now')),
2022-05-19 18:32:04 +08:00
row_status TEXT NOT NULL CHECK (row_status IN ('NORMAL', 'ARCHIVED')) DEFAULT 'NORMAL',
2022-02-03 15:32:03 +08:00
content TEXT NOT NULL DEFAULT '',
visibility TEXT NOT NULL CHECK (visibility IN ('PUBLIC', 'PROTECTED', 'PRIVATE')) DEFAULT 'PRIVATE'
2022-02-03 15:32:03 +08:00
);
2022-05-19 18:32:04 +08:00
-- memo_organizer
CREATE TABLE memo_organizer (
id INTEGER PRIMARY KEY AUTOINCREMENT,
memo_id INTEGER NOT NULL,
user_id INTEGER NOT NULL,
pinned INTEGER NOT NULL CHECK (pinned IN (0, 1)) DEFAULT 0,
UNIQUE(memo_id, user_id)
);
2022-02-03 15:32:03 +08:00
-- shortcut
CREATE TABLE shortcut (
id INTEGER PRIMARY KEY AUTOINCREMENT,
2022-05-17 21:21:13 +08:00
creator_id INTEGER NOT NULL,
2022-02-03 15:32:03 +08:00
created_ts BIGINT NOT NULL DEFAULT (strftime('%s', 'now')),
updated_ts BIGINT NOT NULL DEFAULT (strftime('%s', 'now')),
2022-05-19 18:32:04 +08:00
row_status TEXT NOT NULL CHECK (row_status IN ('NORMAL', 'ARCHIVED')) DEFAULT 'NORMAL',
2022-02-03 15:32:03 +08:00
title TEXT NOT NULL DEFAULT '',
payload TEXT NOT NULL DEFAULT '{}'
2022-02-03 15:32:03 +08:00
);
-- resource
CREATE TABLE resource (
id INTEGER PRIMARY KEY AUTOINCREMENT,
2022-05-17 21:21:13 +08:00
creator_id INTEGER NOT NULL,
created_ts BIGINT NOT NULL DEFAULT (strftime('%s', 'now')),
updated_ts BIGINT NOT NULL DEFAULT (strftime('%s', 'now')),
2022-02-03 15:32:03 +08:00
filename TEXT NOT NULL DEFAULT '',
blob BLOB DEFAULT NULL,
external_link TEXT NOT NULL DEFAULT '',
2022-02-03 15:32:03 +08:00
type TEXT NOT NULL DEFAULT '',
size INTEGER NOT NULL DEFAULT 0,
visibility TEXT NOT NULL CHECK (visibility IN ('PUBLIC', 'PROTECTED', 'PRIVATE')) DEFAULT 'PRIVATE'
2022-02-03 15:32:03 +08:00
);
-- memo_resource
2022-09-21 19:34:54 +08:00
CREATE TABLE memo_resource (
memo_id INTEGER NOT NULL,
resource_id INTEGER NOT NULL,
created_ts BIGINT NOT NULL DEFAULT (strftime('%s', 'now')),
2022-09-30 20:20:00 +08:00
updated_ts BIGINT NOT NULL DEFAULT (strftime('%s', 'now')),
UNIQUE(memo_id, resource_id)
2022-09-21 19:34:54 +08:00
);