image_tagger/TaggerSchemaDefinition.sql
2023-03-14 20:45:01 +01:00

47 lines
1.8 KiB
SQL

PRAGMA foreign_keys = on;
CREATE TABLE IF NOT EXISTS "Descriptor" (
"id" INTEGER PRIMARY KEY NOT NULL,
"descriptor" VARCHAR NOT NULL,
CONSTRAINT "DescriptorName" UNIQUE("descriptor") ON CONFLICT IGNORE
);
CREATE TABLE IF NOT EXISTS "File" (
"id" INTEGER PRIMARY KEY NOT NULL,
"filePath" VARCHAR NOT NULL,
CONSTRAINT "FilePath" UNIQUE("filePath") ON CONFLICT IGNORE
);
CREATE TABLE IF NOT EXISTS "MetaDescriptor" (
"metaDescriptorId" INTEGER NOT NULL,
"infraDescriptorId" INTEGER NOT NULL,
CONSTRAINT "InfraRelationUnique" UNIQUE ("infraDescriptorId") ON CONFLICT REPLACE,
FOREIGN KEY("metaDescriptorId") REFERENCES "Descriptor"("id") ON DELETE CASCADE,
FOREIGN KEY("infraDescriptorId") REFERENCES "Descriptor"("id") ON DELETE CASCADE
);
CREATE TABLE IF NOT EXISTS "Tag" (
"id" INTEGER PRIMARY KEY NOT NULL,
"fileId" INTEGER NOT NULL,
"descriptorId" INTEGER NOT NULL,
"subTagOfId" INTEGER,
CONSTRAINT "TagUnique" UNIQUE (fileId, descriptorId, subTagOfId) ON CONFLICT IGNORE,
FOREIGN KEY("fileId") REFERENCES "File"("id") ON DELETE CASCADE,
FOREIGN KEY("descriptorId") REFERENCES "Descriptor"("id") ON DELETE CASCADE,
FOREIGN KEY ("subTagOfId") REFERENCES "Tag"("id") ON DELETE CASCADE
);
CREATE TABLE IF NOT EXISTS "TaggerDBInfo" (
_tagger INTEGER NOT NULL,
version TEXT NOT NULL,
lastAccessed TEXT,
lastBackup TEXT,
lastAudit TEXT,
lastClean TEXT,
CONSTRAINT uniqueInfo UNIQUE(_tagger) ON CONFLICT REPLACE
);
INSERT INTO Descriptor (descriptor) VALUES ('#ALL#'), ('#META#'), ('#UNRELATED#');
-- relate #META# and #UNRELATED# to #ALL#
INSERT INTO MetaDescriptor (metaDescriptorId, infraDescriptorId)
SELECT
(SELECT id FROM Descriptor WHERE descriptor = '#ALL#'),
id
FROM Descriptor
WHERE descriptor IN ('#META#','#UNRELATED#');
INSERT INTO TaggerDBInfo (_tagger, version, lastAccessed)
VALUES (0, '0.3.2.0', datetime());