Moco[1] is a library that implements automated transformation of an OntoUML model to SQL.
The library can transform any valid OntoUML model into a SQL script that instantiates an empty database, which can store data described by the conceptual model. All constraints implied by the OntoUML model are transformed to database triggers to ensure data consistency.
The transformation is executed in three stages:
-
OntoUML to UML. All class and relationship stereotypes are supported, supports optimization of phases, roles, relators and generalization sets.
-
UML to RDB. Classes, attributes, associations, generalizations, generalization sets and enumerations are supported.
-
RDB to SQL. Tables, columns, primary, unique, foreign keys and derived OCL constraints are supported.
Target RDBM platform is Oracle Database 12c.
This library is primarily intended to be used as a plugin to OpenPonk — a modeling tool that supports OntoUML. A prebuilt distribution of OpenPonk that includes Moco is available at gitlab.fit.cvut.cz/jaburjak/openponk-moco.
The transformation can be invoked by menu Diagram » Moco » Transform to SQL.
You can use Metacello to load the library, as shown below. Moco can be used even outside OpenPonk; in that case, you won’t be able to use the Moco-OpenPonk
package.
Metacello new baseline: 'Moco';
repository: 'github://jaburjak/moco:main';
load.
Currently, OpenPonk nightly released on 2024/03/02 and Pharo 11 are supported.
Created by Jakub Jabůrek, released under the MIT License. Please see the LICENSE file for more information.
The approach for the transformation of OntoUML to SQL was developed by Dr. Zdeněk Rybola in his Ph.D. thesis Towards OntoUML for Software Engineering: Transformation of OntoUML into Relational Databases (2017).