Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Drop object and relationship and keep only entity #215

Open
4 of 7 tasks
manuelma opened this issue Feb 8, 2023 · 0 comments
Open
4 of 7 tasks

Drop object and relationship and keep only entity #215

manuelma opened this issue Feb 8, 2023 · 0 comments
Assignees
Milestone

Comments

@manuelma
Copy link
Collaborator

manuelma commented Feb 8, 2023

This will be the first of a series of issues about data structure and API updates begining with Mopo.

This first big change is both a data structure change and an API change. We will drop the object and relationship tables and have everything in the entity table (I won't say it explicitely but everything I say about object, relationship and entity will of course also apply to object_class, relationship_class and entity_class).

The only thing that will tell the old object and relationship apart is the dimensionality (0 in the case of an object, 1 or more in the case of a relationship). So in the end, we would just have entities with different dimensionality and that is supposed to allow both users and us to reason about the data structure much easier. Also some API calls will look more compact.

This change will be reflected in the API so instead of dealing with objects and relationships, the API user will deal exclusively with entities. And this of course means the UI needs to also be updated to present stuff in terms of entity rather than object and relationship. This will be a big change and needs to be done gradually. My plan is the following:

  1. Upgrade the DB structure: drop object and relationship tables
  2. Upgrade the current API to work with the entity table rather than with the object and relationship tables. At this point, the API will remain unchanged so all the clients, including UI, will continue to work, look and feel as they do today.
  3. Implement new API to manipulate entities directly (rather than manipulating objects and relationships separately)
  4. Gradually upgrade clients (UI, import mapping, export mapping, SpineInterface, long etcetera) to use the entity API in places where they are using the object/relationship API
  5. Add deprecation notices to the old API that deals with objects and relationships.
  6. Pray that all API users (including ourselves in our own institutions) also upgrade their calls to use the new entity API.
  7. Fast-forward one year or more in the future. Remove the old object and relationship API if it bothers us.

I added 'if it bothers us' at the end because the old API may prove maintainable and in that case we can save us a huge headache.

@manuelma manuelma self-assigned this Feb 8, 2023
soininen added a commit that referenced this issue May 22, 2023
soininen added a commit to spine-tools/Spine-Toolbox that referenced this issue May 22, 2023
SpecificationEditorWindowBase._make_new_specification() signature has
changed but not all code was adapted to the change.

Re spine-tools/Spine-Database-API#215
@jkiviluo jkiviluo added this to the v0.8 milestone Aug 29, 2023
@soininen soininen modified the milestones: v0.8.0, v0.8.1 Apr 30, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants