Hi all!
I want to present a small library which provides a mix task for generating an Entity-Relationship Diagram for Ecto schemas.
You can check examples of output for a couple of open-source projects in docs or directly on GitHub.
Links:
Hi all!
I want to present a small library which provides a mix task for generating an Entity-Relationship Diagram for Ecto schemas.
You can check examples of output for a couple of open-source projects in docs or directly on GitHub.
Links:
Neat! Would be cool to be possible to generate input for https://dbdiagram.io.
Thank you for the suggestion, will add this to the roadmap
Added DBML support in version 0.2.0
Added QuickDBD support in version 0.3.0
@fuelen thank you so much! I just used Ecto.ERD
and it worked nicely.
Very cool. Thanks a lot.
It could probably replace ERAlchemy the tool I’m still using for this kind of documentation task.
Added PlantUML support in version 0.4.0
Added Mermaid support in version 0.5.0
Just used this for a take-home coding assessment where I’m asked to dissect an existing Ecto schema and fix some related tests.
This lib and the ERD it generated were extremely helpful. Thank you for building this!
Looks awesome. Going to test it soon. Thanks!
Edit: Just tried all formats and my favourite one is PlantUML
as it’s generating best graph images.
I would like to suggest small changes:
ecto
internallyid
to something like: id : id (schema_name.table_name)
(as passed to schema
macro)?id
fields to something like field_name : id (schema_name.table_name.foreign_key_field_name)
Elixir
module, so we have just short MyContext.MySchema
instead of MyApp.MyContext.MySchema
?So for example instead of:
MyApp.MyContext.MySchema |
---|
id : id |
source_field_id : id string_field : string |
we would have:
MyContext.MySchema |
---|
id : id (public.my_table_name) |
assoc_field : belongs to (public.my_another_table_name.source_field_id) string_field : string |
Thank you for detailed feedback!
Sounds reasonable, but if there is an app that works with this table somehow, then we’d have to add more options to show the schema again. As for now, it can be easily removed using config file:
[
map_node: fn
%{source: "schema_migrations"} -> nil
node -> node
end
]
Primary keys are not required. Seems like you just want to see a table name. I think there are better ways of doing this, like add one more row which shows schema prefix and table name.
It is a bit noisy. The downside of PlantUML
is that it doesn’t support precise connections between fields (using arrows), as it is done in our dot renderer.
What do you like in PlantUML
the most? AFAIK, it uses Graphviz
under the hood, and maybe we can modify/add an option to our dot renderer to have similar experience.
That’s a good idea to have an ability to format module name, but definitely not by default, as such names can overlap.
I think working with that table is bad practice. First of all ecto
rely on it, so developer should not:
I don’t also see how other libraries are gonna using it and what’s more important is that schema_mirations
is not documented anywhere in ecto
and ecto_sql
hex documentation (there is only schema_miration
option in Repo
callback). I would say that using schema_mirations
table in any way is like using a private API.
Yeah, I completely forgot about that In that case it should be in new line under
Module.Name
.
In my personal opinion the diagram is the most clear. It’s not like that from very start I liked the arrows (maybe legend for them?) or colors, but I was used to it very quickly.
Yes, I also reminded that there could be for example .Schema
suffix, so it’s better to make it easily configurable.
Ok, after modifications this is what I have in mind:
MyContext.MySchema my_schema.my_table |
---|
id : id |
assoc_field (assoc_field_id) : id (foreign_key_id) string_field (legacy_string_field_source) : string integer_field : int |
If we could make DOT
layout looks like PlantUML
image then yes - with field connection it would be even more amazing and we do not need to note foreign_key_id
then.
Generally I would like to use such graphs to show other people context about planned API
(context + module) and database
structure (source fields). This is why for example MyApp
is completely not needed and so on …