trilium/db/schema.sql

115 lines
6.4 KiB
MySQL
Raw Normal View History

2021-01-31 05:17:29 +08:00
CREATE TABLE IF NOT EXISTS "entity_changes" (
`id` INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
`entityName` TEXT NOT NULL,
`entityId` TEXT NOT NULL,
`hash` TEXT NOT NULL,
`isErased` INT NOT NULL,
`changeId` TEXT NOT NULL,
`componentId` TEXT NOT NULL,
2022-01-10 04:25:15 +08:00
`instanceId` TEXT NOT NULL,
2021-01-31 05:17:29 +08:00
`isSynced` INTEGER NOT NULL,
`utcDateChanged` TEXT NOT NULL
);
2022-01-11 00:09:20 +08:00
CREATE TABLE IF NOT EXISTS "etapi_tokens"
(
2022-01-11 00:09:20 +08:00
etapiTokenId TEXT PRIMARY KEY NOT NULL,
2022-01-08 02:33:59 +08:00
name TEXT NOT NULL,
2022-01-11 00:09:20 +08:00
tokenHash TEXT NOT NULL,
2021-01-31 05:17:29 +08:00
utcDateCreated TEXT NOT NULL,
2022-01-11 04:24:07 +08:00
utcDateModified TEXT NOT NULL,
2021-01-31 05:17:29 +08:00
isDeleted INT NOT NULL DEFAULT 0);
2020-01-03 17:48:36 +08:00
CREATE TABLE IF NOT EXISTS "branches" (
`branchId` TEXT NOT NULL,
`noteId` TEXT NOT NULL,
`parentNoteId` TEXT NOT NULL,
`notePosition` INTEGER NOT NULL,
`prefix` TEXT,
`isExpanded` INTEGER NOT NULL DEFAULT 0,
`isDeleted` INTEGER NOT NULL DEFAULT 0,
`deleteId` TEXT DEFAULT NULL,
2021-11-21 20:44:52 +08:00
`utcDateModified` TEXT NOT NULL,
2020-01-03 17:48:36 +08:00
PRIMARY KEY(`branchId`));
2020-08-19 04:37:23 +08:00
CREATE TABLE IF NOT EXISTS "notes" (
`noteId` TEXT NOT NULL,
`title` TEXT NOT NULL DEFAULT "note",
`isProtected` INT NOT NULL DEFAULT 0,
`type` TEXT NOT NULL DEFAULT 'text',
`mime` TEXT NOT NULL DEFAULT 'text/html',
`isDeleted` INT NOT NULL DEFAULT 0,
`deleteId` TEXT DEFAULT NULL,
`dateCreated` TEXT NOT NULL,
`dateModified` TEXT NOT NULL,
`utcDateCreated` TEXT NOT NULL,
`utcDateModified` TEXT NOT NULL,
PRIMARY KEY(`noteId`));
2020-12-15 22:30:46 +08:00
CREATE TABLE IF NOT EXISTS "note_contents" (
`noteId` TEXT NOT NULL,
`content` TEXT NULL DEFAULT NULL,
`dateModified` TEXT NOT NULL,
`utcDateModified` TEXT NOT NULL,
PRIMARY KEY(`noteId`)
);
2020-08-19 04:37:23 +08:00
CREATE TABLE IF NOT EXISTS "note_revisions" (`noteRevisionId` TEXT NOT NULL PRIMARY KEY,
`noteId` TEXT NOT NULL,
2020-12-15 22:30:46 +08:00
type TEXT DEFAULT '' NOT NULL,
mime TEXT DEFAULT '' NOT NULL,
2022-01-13 02:32:23 +08:00
`title` TEXT NOT NULL,
2020-08-19 04:37:23 +08:00
`isProtected` INT NOT NULL DEFAULT 0,
`utcDateLastEdited` TEXT NOT NULL,
`utcDateCreated` TEXT NOT NULL,
`utcDateModified` TEXT NOT NULL,
`dateLastEdited` TEXT NOT NULL,
2020-12-15 22:30:46 +08:00
`dateCreated` TEXT NOT NULL);
CREATE TABLE IF NOT EXISTS "note_revision_contents" (`noteRevisionId` TEXT NOT NULL PRIMARY KEY,
2023-01-25 16:55:29 +08:00
`content` TEXT,
2020-12-15 22:30:46 +08:00
`utcDateModified` TEXT NOT NULL);
CREATE TABLE IF NOT EXISTS "options"
(
name TEXT not null PRIMARY KEY,
2022-01-13 02:32:23 +08:00
value TEXT not null,
2020-12-15 22:30:46 +08:00
isSynced INTEGER default 0 not null,
utcDateModified TEXT NOT NULL
2020-08-19 04:37:23 +08:00
);
2020-12-15 22:30:46 +08:00
CREATE TABLE IF NOT EXISTS "attributes"
(
attributeId TEXT not null primary key,
noteId TEXT not null,
type TEXT not null,
name TEXT not null,
value TEXT default '' not null,
position INT default 0 not null,
utcDateModified TEXT not null,
isDeleted INT not null,
`deleteId` TEXT DEFAULT NULL,
isInheritable int DEFAULT 0 NULL);
2021-01-31 05:17:29 +08:00
CREATE UNIQUE INDEX `IDX_entityChanges_entityName_entityId` ON "entity_changes" (
`entityName`,
`entityId`
);
CREATE INDEX `IDX_branches_noteId_parentNoteId` ON `branches` (`noteId`,`parentNoteId`);
CREATE INDEX IDX_branches_parentNoteId ON branches (parentNoteId);
CREATE INDEX `IDX_notes_title` ON `notes` (`title`);
CREATE INDEX `IDX_notes_type` ON `notes` (`type`);
CREATE INDEX `IDX_notes_dateCreated` ON `notes` (`dateCreated`);
CREATE INDEX `IDX_notes_dateModified` ON `notes` (`dateModified`);
CREATE INDEX `IDX_notes_utcDateModified` ON `notes` (`utcDateModified`);
CREATE INDEX `IDX_notes_utcDateCreated` ON `notes` (`utcDateCreated`);
CREATE INDEX `IDX_note_revisions_noteId` ON `note_revisions` (`noteId`);
CREATE INDEX `IDX_note_revisions_utcDateCreated` ON `note_revisions` (`utcDateCreated`);
CREATE INDEX `IDX_note_revisions_utcDateLastEdited` ON `note_revisions` (`utcDateLastEdited`);
CREATE INDEX `IDX_note_revisions_dateCreated` ON `note_revisions` (`dateCreated`);
CREATE INDEX `IDX_note_revisions_dateLastEdited` ON `note_revisions` (`dateLastEdited`);
2022-01-10 04:25:15 +08:00
CREATE INDEX `IDX_entity_changes_changeId` ON `entity_changes` (`changeId`);
CREATE INDEX IDX_attributes_name_value
on attributes (name, value);
CREATE INDEX IDX_attributes_noteId_index
on attributes (noteId);
CREATE INDEX IDX_attributes_value_index
on attributes (value);
2021-02-13 06:30:11 +08:00
CREATE TABLE IF NOT EXISTS "recent_notes"
(
noteId TEXT not null primary key,
notePath TEXT not null,
utcDateCreated TEXT not null
);