Draft: for 3d Asset Schema Design and Database Backend Selection
Context
The current project involves creating a schema for storing VRM license data, GLTF 3d assets, and other metadata. The data will be stored in a public.cbf_avatar
table with fields such as created_at
, gltf_embedded
, id
, and xmp
.
Problem Statement
The main challenge is deciding on the appropriate database backend and determining whether storing large files in a relational database is a good practice.
Proposed Solution
CREATE TABLE public.cbf_avatar (
DEFAULT now() NOT NULL,
created_at timestamptz DEFAULT '{}'::jsonb NOT NULL,
gltf_embedded jsonb id uuid DEFAULT gen_random_uuid() NOT NULL,
DEFAULT '{}'::jsonb NOT NULL,
xmp jsonb CONSTRAINT cbf_avatar_pkey PRIMARY KEY (id)
);
The proposed solution involves using either Supabase PostgreSQL or FoundationDB with SQLite as the database backend. The gltf_embedded
field will store GLTF 3d asset data as JSON binary, while the xmp
field will store VRM license data and other metadata.
Benefits
- The use of JSON binary allows for efficient storage and retrieval of GLTF 3d assets.
- The chosen database backends are robust and reliable, ensuring data integrity and consistency.
Downsides
- Storing large files in a relational database could potentially lead to disk thrashing and other performance issues.
- Fields in databases generally have a size limit, which could pose problems if the data exceeds this limit.
The Road Not Taken
An alternative approach would be to store the large files in a separate file system and only keep references to these files in the database. However, this might complicate the data management process.
Infrequent Use Case
This schema design and database backend selection may not be suitable for applications that require extremely high performance or have strict limitations on data size.
In Core and Done by Us
The schema design and database backend selection will be implemented by the V-Sekai development team.
Status
Status: Draft
Decision Makers
- V-Sekai development team
Further Reading
- V-Sekai · GitHub - Official GitHub account for the V-Sekai development community focusing on social VR functionality for the Godot Engine
- V-Sekai/v-sekai-game - GitHub page for the V-Sekai open-source project bringing social VR/VRSNS/metaverse components to the Godot Engine
- Postgres Storing Large Text - A 2020 article suggesting that larger file storage in a relational database is okay.
This proposal was assisted by Aria, an AI assistant.