Por fin encontré una forma sencilla de generar un diagrama de Entidad-Relación de una base de datos existente con MySql Workbench.

Para poder generar el esquema de base de datos, debemos utilizar MySQL Workbench. Es una aplicación gratuita de MySQL de Oracle. Podéis descargar MySQL WorkBench desde aquí.

(Artículo revisado con MySQL WorkBench 8.0.16. Las capturas de pantalla siguen siendo iguales)

También te puede interesar:
Cambiar la contraseña de root de MySQL
Consultas MySQL mediante una macro de VB
Guía de administración de MySQL
Guía para crear una base de datos MySQL desde comandos en linux

libro diagrama entidad relaciónPincha en la imagen para saber más sobre este libro

Cómo generar el Diagrama Entidad Relación desde MySQL Workbench

Una vez instalada y configurada nuestra conexión a la base de datos de la que queremos obtener su "Diagrama Entidad-Relación", nos vamos al menú superior Database y seleccionamos la opción de Reverse Engineer (Ingeniería inversa):

MySQL Workbench Reverse Engineer
Se nos mostrará la siguiente ventana donde seleccionamos nuestra conexión a la base de datos, localhost, y pulsamos Next (Siguiente):

Definir cadena de conexión MySQL
Cuando termine el proceso, volvemos a pulsar Next:

Connect to DBMS MySQL
Seleccionamos la base de datos que nos interese y pulsamos Next:

Seleccionar base de datos MySQL
Cuando termine el proceso, volvemos a pulsar Next:

Finalizar proceso

Seleccionar objetos a importar mediante ingeniería inversa

En la siguiente ventana debemos seleccionar qué objetos queremos incluir en nuestro diagrama entidad relación. En nuestro caso seleccionaremos todos. Es importante seleccionar el check que aparece en la parte inferior. En algunas ocasiones me ha ocurrido que no me deja seleccionarlo porque a lo mejor hay demasiados objetos seleccionados. Pulsamos Next para continuar:

Importar tablas MySQL
Cuando termine el proceso, volvemos a pulsar Next:

Finalizar proceso
Si todo sale correctamente debería aparecernos una ventana como la siguiente:

Resultado de ingeniería inversa de objetos MySQL
Pulsamos Finish para terminar y debería mostrarnos el diagrama con todas las tablas de nuestra base de datos. En algunas ocasiones sólo importa las tablas sin establecer las relaciones entre estas. Esto se debe a que esa información no existe en las tablas, muy común en aplicaciones de software libre.

Resultado de la ingeniería inversa: modelo MySQL

El modelo MySQL de la BBDD tras la realización de la ingeniería inversa es el siguiente.

Diagrama Entidad Relación generado con MySQL Workbench

Relaciones en MySQL Workbench

Si nos fijamos bien, las tablas que tienen dibujadas las relaciones es porque tienen esa información creada:

Listado de foreign keys de una tabla MySQL
En cambio, aquí podemos ver una tabla que sí dispone de las columnas foráneas:

Ausencia de foreign keys de una tabla de MySQL

pero que no dispone de dicha información creada:

Ausencia de foreign keys de una tabla MySQL

Por ese motivo, no dibuja las relaciones en el diagrama entidad relación.

libro diagrama entidad relaciónPincha en la imagen para saber más sobre este libro

Una vez que ya tenemos el diagrama completo, podremos imprimirlo y tomar anotaciones de cada una de las tablas así como colocarlas a nuestro gusto para que nos sea más fácil leer el diagrama.

Diagrama entidad relación completo de una base de datos MySQL

Identificar qué campos están relacionados dentro del modelo

Además de conseguir el diagrama, hay dos cosas que me han gustado bastante de esta herramienta, aunque parezca una chorrada, son las siguientes.

Si nos posicionamos sobre una relación entre tablas, ésta se sombrea e indica qué campos de las tablas son los que están relacionados. Esto es muy útil porque visualmente no es fácil saber qué columnas están relacionadas. Hay muchas aplicaciones de Software Libre que utilizan una nomenclatura sencilla en los campos e incluso en algunas ocasiones les dan nombres genéricos porque se tratan de claves primarias que sirven para multitud de tipos de Entidades, por lo que el poder visualizar esto hace que sea más sencillo elaborar tu consultas SQL:

Claves foráneas entre dos tablas MySQL

Modificar el tipo del diagrama del modelo de datos en MySQL Workbench

Y la otra cosa que también es muy útil, es que permite modificar el tipo de diagrama para que lo anterior sea más sencillo todavía. Desde el menú superior, en Model, y en el menú Relationship Notation podemos seleccionar el estilo del diagrama. Por defecto viene seleccionado "Crow´s Foot (IE)" pero si seleccionamos Connect to Columns podremos ver directamente las relaciones sobre los campos implicados.

Mostrar conexiones entre tablas MySQL

El diagrama se mostraría de la siguiente manera, indicando además la cardinalidad de las relaciones con simbología más clara si no tenemos grandes conocimientos de UML:

Simbología relacional entre tablas de una base de datos

La única pega que tiene es que no dibuja las relaciones con líneas horizontales y verticales. Utiliza líneas diagonales y el díbujo queda un poco más feo. Pero por lo menos ayuda a interpretar el esquema de la base de datos.

Conclusiones

Esta es una forma de poder obtener un diagrama de una base de datos existente. Si has creado una base de datos con MySQL y quieres dibujar su esquema, esta sería la forma más rápida.

Espero que os haya gustado y os sirva de utilidad.

Guardar

Uso de cookies

Este sitio web utiliza cookies para que usted tenga la mejor experiencia de usuario. Si continúa navegando está dando su consentimiento para la aceptación de las mencionadas cookies y la aceptación de nuestra política de cookies, pinche el enlace para mayor información.

ACEPTAR
Aviso de cookies