Effortless ERD Design With Prisma Markdown
Written by Nikos Vaggalis   
Monday, 21 October 2024

Prisma Markdown is a new tool that takes the pain out of drawing entity relationship diagrams. An essential help if your design is database driven rather than code driven.

It's always exciting to discover new, useful and open source tools, especially on the database/SQL front. We've examined some of them in the past, like Azimutt, a database schema explorer with many great features. 

Azimutt could read your SQL DDL and generate an ERD out of it, but that wasn't all it could do. Among other things it could also :

  • search for relevant tables
  • follow the relations
  • list relations
  • analyze your schema to provide you insights
  • build possible paths between two tables you want to join

It was great help in trying to reverse engineer a third party schema to base a Spring Boot application upon. If you want to get all the details then make sure to follow the link to that article at the end of the this one.

Another tool was ERDLab, an intuitive SQL Visualization Tool which helps in capturing your database design thoughts.
To be exact, ERDLab falls into the SQL schema visualization tools category. It allows you not only to draw your database design visually but also do so in code. And it's not just drawing per se; you can interact with your schema and explore its relationships end to end and collaborate on it in a team.

With both of those tools you could render an ERD starting from the SQL DDL code, aka code driven, or by drawing it using a GUI. If on the other hand you are starting the other way around, that is start from the ERD to then get to the code and don't want to use a GUI to draw it but instead use text to describe it to generate it automatically from it, then this new tool is for you; Prisma Markdown.

prismalogo

Prisma Markdown can automatically generate ERDs while, importantly covering the documentation aspect as well. In addition, by utilizing the concept of pagination, prisma-markdown can draw diagrams properly even if the number of tables exceeds the hundreds or thousands.

You just add a few tags to annotate your model and relationships which are then prepared in a diagram. Let's see a simple example, of a table called "bbs_article" with a 1:n mandatory relationship to "snapshots bbs_article_snapshots"
and a 1:n optional to "bbs_article_comments". This is how you would describe the model:

But that's not all! Let's not forget the 'documentation' part not just the diagram. So, annotating the model with comments:

you get that nicely rendered HTML:

A very handy tag is that of the Namespace, handy when your database has many models. @namespace can render those to multiple paginated diagrams, separated to proper sections of markdown document. For instance the case we examined above belongs to the @namespace of "Articles".

To start with it you can install the tool with

npm i -D prisma-markdown

Next, add the generator to the schema file

datasource db {
provider = "postgresql"
url = env("POSTGRES_URL")
}

generator client {
provider = "prisma-client-js"
previewFeatures = ["views"]
}

generator markdown {
provider = "node ./lib/executable/markdown"
title = "Implicit M: N relationships"
output = "./implicit.md"
}

and then write the comments and annotate the models.

When ready just run

npx prisma generate

to generate the ERD/documentation.

With that said, the tool's Github repo is full of examples of diagrams to get started with. The specific example we used for this article can be found here and here.

Making a dev's life a little bit easier...

prismalogo

More Information

prisma-markdown

Related Articles

Entity Relationship Diagraming with ERDLab

Real World Schema Exploring With Azimutt

 

To be informed about new articles on I Programmer, sign up for our weekly newsletter, subscribe to the RSS feed and follow us on Twitter, Facebook or Linkedin.

Banner


Prometheus 3 Adds New UI
15/01/2025

Prometheus 3 has been released, the first major release in seven years. The new version has a new UI and native support in Remote-Write for new elements.



Meta's MultiModal, MultiLingual Translator
21/01/2025

Meta has taken us a long way towards creating a Babel Fish, a tool that helps individuals translate speech between any two languages. This is thanks to SEAMLESSM4T which is open-source for non-co [ ... ]


More News

espbook

 

Comments




or email your comment to: comments@i-programmer.info

Last Updated ( Monday, 21 October 2024 )