Replace document_id with relative path

This commit is contained in:
Andras Schmelczer 2024-12-14 14:59:29 +00:00
parent 476c0ed672
commit fe7ff5349d
No known key found for this signature in database
GPG key ID: FC8F2C3D3D1A718C
11 changed files with 83 additions and 270 deletions

View file

@ -1,27 +1,25 @@
CREATE TABLE IF NOT EXISTS documents (
vault_id TEXT NOT NULL,
document_id TEXT NOT NULL,
relative_path TEXT NOT NULL,
version_id INTEGER NOT NULL,
created_date TIMESTAMP NOT NULL,
updated_date TIMESTAMP NOT NULL,
relative_path TEXT NOT NULL,
content BLOB NOT NULL,
is_binary BOOLEAN NOT NULL,
is_deleted BOOLEAN NOT NULL,
PRIMARY KEY (vault_id, document_id, version_id)
PRIMARY KEY (vault_id, relative_path, version_id)
);
CREATE VIEW IF NOT EXISTS latest_documents AS
CREATE VIEW IF NOT EXISTS latest_document_versions AS
SELECT d.*
FROM documents d
INNER JOIN (
SELECT vault_id, document_id, MAX(version_id) AS max_version_id
SELECT vault_id, relative_path, MAX(version_id) AS max_version_id
FROM documents
GROUP BY vault_id, document_id
GROUP BY vault_id, relative_path
) max_versions
ON d.vault_id = max_versions.vault_id
AND d.document_id = max_versions.document_id
AND d.relative_path = max_versions.relative_path
AND d.version_id = max_versions.max_version_id;
CREATE INDEX IF NOT EXISTS idx_documents_vault_doc
ON documents (vault_id, document_id);
ON documents (vault_id, relative_path);