2017-12-11 11:16:20 +08:00
|
|
|
CREATE TABLE IF NOT EXISTS "sync" (
|
2019-03-25 04:06:38 +08:00
|
|
|
`id` INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
|
|
|
|
`entityName` TEXT NOT NULL,
|
|
|
|
`entityId` TEXT NOT NULL,
|
|
|
|
`sourceId` TEXT NOT NULL,
|
|
|
|
`utcSyncDate` TEXT NOT NULL);
|
2018-02-01 12:36:39 +08:00
|
|
|
CREATE TABLE IF NOT EXISTS "source_ids" (
|
2019-03-25 04:06:38 +08:00
|
|
|
`sourceId` TEXT NOT NULL,
|
|
|
|
`utcDateCreated` TEXT NOT NULL,
|
|
|
|
PRIMARY KEY(`sourceId`)
|
2017-12-04 11:29:23 +08:00
|
|
|
);
|
2018-04-03 10:33:54 +08:00
|
|
|
CREATE TABLE IF NOT EXISTS "api_tokens"
|
2018-01-11 13:01:16 +08:00
|
|
|
(
|
2018-04-03 10:33:54 +08:00
|
|
|
apiTokenId TEXT PRIMARY KEY NOT NULL,
|
|
|
|
token TEXT NOT NULL,
|
2019-03-25 04:06:38 +08:00
|
|
|
utcDateCreated TEXT NOT NULL,
|
|
|
|
isDeleted INT NOT NULL DEFAULT 0,
|
|
|
|
hash TEXT DEFAULT "" NOT NULL);
|
2018-06-02 10:26:37 +08:00
|
|
|
CREATE TABLE IF NOT EXISTS "options"
|
|
|
|
(
|
2018-06-14 07:10:28 +08:00
|
|
|
name TEXT not null PRIMARY KEY,
|
2018-06-02 10:26:37 +08:00
|
|
|
value TEXT,
|
|
|
|
isSynced INTEGER default 0 not null,
|
|
|
|
hash TEXT default "" not null,
|
2019-03-25 04:06:38 +08:00
|
|
|
utcDateCreated TEXT not null,
|
|
|
|
utcDateModified TEXT NOT NULL
|
2018-04-11 12:10:11 +08:00
|
|
|
);
|
2019-03-25 04:06:38 +08:00
|
|
|
CREATE TABLE IF NOT EXISTS "attributes"
|
2018-07-29 17:47:46 +08:00
|
|
|
(
|
2018-08-13 13:57:23 +08:00
|
|
|
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,
|
2019-03-25 04:06:38 +08:00
|
|
|
utcDateCreated TEXT not null,
|
|
|
|
utcDateModified TEXT not null,
|
2018-08-13 13:57:23 +08:00
|
|
|
isDeleted INT not null,
|
2019-03-25 04:06:38 +08:00
|
|
|
hash TEXT default "" not null,
|
|
|
|
isInheritable int DEFAULT 0 NULL);
|
2019-02-21 06:07:57 +08:00
|
|
|
CREATE TABLE IF NOT EXISTS "notes" (
|
2019-03-25 04:06:38 +08:00
|
|
|
`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',
|
|
|
|
`hash` TEXT DEFAULT "" NOT NULL,
|
|
|
|
`isDeleted` INT NOT NULL DEFAULT 0,
|
|
|
|
`dateCreated` TEXT NOT NULL,
|
|
|
|
`dateModified` TEXT NOT NULL,
|
|
|
|
`utcDateCreated` TEXT NOT NULL,
|
|
|
|
`utcDateModified` TEXT NOT NULL,
|
|
|
|
PRIMARY KEY(`noteId`)
|
2019-02-21 06:07:57 +08:00
|
|
|
);
|
2019-03-12 03:36:19 +08:00
|
|
|
CREATE UNIQUE INDEX `IDX_sync_entityName_entityId` ON `sync` (
|
2019-03-25 04:06:38 +08:00
|
|
|
`entityName`,
|
|
|
|
`entityId`
|
|
|
|
);
|
|
|
|
CREATE INDEX `IDX_sync_utcSyncDate` ON `sync` (
|
|
|
|
`utcSyncDate`
|
|
|
|
);
|
2019-03-12 03:36:19 +08:00
|
|
|
CREATE INDEX IDX_attributes_name_value
|
|
|
|
on attributes (name, value);
|
|
|
|
CREATE INDEX IDX_attributes_name_index
|
|
|
|
on attributes (name);
|
|
|
|
CREATE INDEX IDX_attributes_noteId_index
|
|
|
|
on attributes (noteId);
|
|
|
|
CREATE INDEX IDX_attributes_value_index
|
|
|
|
on attributes (value);
|
2019-10-19 18:36:16 +08:00
|
|
|
CREATE TABLE IF NOT EXISTS "note_contents" (
|
|
|
|
`noteId` TEXT NOT NULL,
|
|
|
|
`content` TEXT NULL DEFAULT NULL,
|
|
|
|
`hash` TEXT DEFAULT "" NOT NULL,
|
|
|
|
`utcDateModified` TEXT NOT NULL,
|
|
|
|
PRIMARY KEY(`noteId`)
|
|
|
|
);
|
|
|
|
CREATE TABLE recent_notes
|
|
|
|
(
|
|
|
|
noteId TEXT not null primary key,
|
|
|
|
notePath TEXT not null,
|
|
|
|
hash TEXT default "" not null,
|
|
|
|
utcDateCreated TEXT not null,
|
|
|
|
isDeleted INT
|
|
|
|
);
|
|
|
|
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,
|
|
|
|
`utcDateModified` TEXT NOT NULL,
|
|
|
|
utcDateCreated TEXT NOT NULL,
|
|
|
|
hash TEXT DEFAULT "" NOT NULL,
|
|
|
|
PRIMARY KEY(`branchId`));
|
|
|
|
CREATE INDEX `IDX_branches_noteId` ON `branches` (`noteId`);
|
|
|
|
CREATE INDEX `IDX_branches_noteId_parentNoteId` ON `branches` (`noteId`,`parentNoteId`);
|
|
|
|
CREATE INDEX IDX_branches_parentNoteId ON branches (parentNoteId);
|
2019-11-02 03:00:56 +08:00
|
|
|
CREATE TABLE IF NOT EXISTS "note_revisions" (`noteRevisionId` TEXT NOT NULL PRIMARY KEY,
|
|
|
|
`noteId` TEXT NOT NULL,
|
|
|
|
`title` TEXT,
|
|
|
|
`contentLength` INT NOT NULL,
|
|
|
|
`isProtected` INT NOT NULL DEFAULT 0,
|
|
|
|
`utcDateLastEdited` TEXT NOT NULL,
|
|
|
|
`utcDateCreated` TEXT NOT NULL,
|
|
|
|
`utcDateModified` TEXT NOT NULL,
|
|
|
|
`dateLastEdited` TEXT NOT NULL,
|
|
|
|
`dateCreated` TEXT NOT NULL,
|
|
|
|
type TEXT DEFAULT '' NOT NULL,
|
|
|
|
mime TEXT DEFAULT '' NOT NULL,
|
|
|
|
hash TEXT DEFAULT '' NOT NULL);
|
|
|
|
CREATE TABLE IF NOT EXISTS "note_revision_contents" (`noteRevisionId` TEXT NOT NULL PRIMARY KEY,
|
|
|
|
`content` TEXT,
|
|
|
|
hash TEXT DEFAULT '' NOT NULL,
|
|
|
|
`utcDateModified` TEXT NOT NULL);
|
|
|
|
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`);
|