Abstract
Background A large volume of heavily fragmented data is generated daily in different healthcare contexts and is stored using various structures with different semantics. This fragmentation and heterogeneity make secondary use of data a challenge. Data integration approaches that derive a common data model from sources or requirements have some advantages. However, these approaches are often built for a specific application where the research questions are known. Thus, the semantic and structural reconciliation is often not reusable nor reproducible. A recent integration approach using knowledge models has been developed with ontologies that provide a strong semantic foundation. Nonetheless, deriving a data model that captures the richness of the ontology to store data with their full semantic remains a challenging task.
Objectives This article addresses the following question: How to design a sharable and interoperable data model for storing heterogeneous healthcare data and their semantic to support various applications?
Method This article describes a method using an ontological knowledge model to automatically generate a data model for a domain of interest. The model can then be implemented in a relational database which efficiently enables the collection, storage, and retrieval of data while keeping semantic ontological annotations so that the same data can be extracted for various applications for further processing.
Results This article (1) presents a comparison of existing methods for generating a relational data model from an ontology using 23 criteria, (2) describes standard conversion rules, and (3) presents O n t o R e l a , a prototype developed to demonstrate the conversion rules.
Conclusion This work is a first step toward automating and refining the generation of sharable and interoperable relational data models using ontologies with a freely available tool. The remaining challenges to cover all the ontology richness in the relational model are pointed out.
Keywords: heterogeneous data, information, data integration, ontologies, management
Introduction
A large volume of healthcare data is generated daily in many contexts. In some of them, data are heavily fragmented across multiple heterogeneous systems. To provide care, manage a hospital, run clinical trials, or help clinicians make better decisions, the core need is to understand an individual's data through a broad scope (e.g., billing relies on integrating diagnosis and treatment data to sum the costs). Consequently, the semantic and structural reconciliation for the secondary use of data is a challenging task that can lead to incorrect interpretation if not correctly automated and verified.
This challenge is compounded by the fact that health data are highly dependent on contextual information. For example, a diabetes code could represent a working diagnosis, an established diagnosis, a family history of diabetes, or even a reason to ask for a test. Thus, to operate safely, the processes rely not only on accessing data from multiple systems, but also on the semantic of the data. 1 The semantics include the nature of the element (e.g., being a patient is a role, the same individual can have the role of a patient when going to the emergency for a fracture fixed, but also the role of a physician when coming to work as an orthopaedic surgeon to fix a fracture) and explicit relationships with other elements (e.g., a diagnosis of diabetes is about an individual who is my mother).
Accordingly, this article addresses the question: How to design a sharable and interoperable data model for storing heterogeneous healthcare data and its semantic to support various applications?
In many heterogeneous environments, a sharable and interoperable data model based on a knowledge model has been demonstrated as a valid approach to decipher the structure and identify relevant data elements to be extracted or combined in a semantically interoperable sound way. 2 Furthermore, to control data integrity while manipulating a large amount of data, a relational database (RDB) is an appropriate system to store data due to its embedded access control, transaction management, data integrity control, efficiency, and performance. 3 However, conventional techniques (entity-relationship, star schema, object-oriented techniques) do not provide sufficient semantic or contextual information for efficient use of a data model in a heterogeneous environment and ensure reliable reuse of data outside a restricted field of its original application. 1 4 Moreover, data generated across different systems (e.g., health ministries, pharmacies, clinics, hospitals) are often stored in RDBs, but their semantic is rarely documented or updated. In other words, conventional techniques do not offer adequate construct to allow the unification of data with their semantic. Thus, the multiple stages of data processing and the exchanges that take place along the way can result in incomplete semantics of the extracted dataset. Therefore, a domain with such fragmentation and multiple data providers but with very low error tolerance needs a new approach to encapsulate the data and their semantics into the same structure that can be shared and reused for multiple applications. Healthcare is one such domain, as life and death decisions will be based on these data.
Various approaches exist 5 to access or integrate data from multiple sources. These approaches use different kinds of inputs. Source-driven approaches use the data source's structure. Requirement-driven approaches use the user requirements for a specific application. Hybrid approaches combine the data structure of the sources and user requirements. Finally, knowledge-driven approaches derive the data model from the knowledge model of the domain. The knowledge-driven approach is arguably the most appropriate for the healthcare domain. Indeed, using a source-driven approach is an arduous task because data sources are structured according to the underlying application, and the addition of new sources will often lead to changes to the model. Moreover, using requirements is impractical because of the diversity and evolution of user requirements. Finally, neither of these last two approaches gives access (by themselves) to explicit semantic as the predicates associated with a data model are always dependent on the source application or a set of user requirements at a specific point in time. On the contrary, a knowledge-driven approach can provide a more stable data model in which the semantic is made explicit 1 and can serve various applications.
Biomedical formal ontologies have been used to formalize biomedical knowledge (e.g., genetics with Gene Ontology and the ontology for biomedical investigations, a reference in the field). They have been successfully used to support many data-related processes such as data integration, data annotation, and classification in many projects. 6 7 8 Developing biomedical formal ontologies is becoming more and more mature, and an international community, the OBO Foundry, is engaged in creating, coordinating, and maintaining these biomedical ontologies. 9 A realist ontology can be defined as “ classes that denote exclusively entities that exist objectively in reality and [whose] definitions adhere to strict criteria to ensure that the classes are reusable in other ontologies while preserving their ontological commitment. ” 10 Thus, these ontologies can be used as a knowledge model to describe a specific domain of discourse objectively and formally. Therefore, deriving a relational data model directly from an ontology can be hypothesized to be the best way to leverage heterogeneous data and their semantic while ensuring integrity and concurrency access for various applications. Specifically, a relational data model generated from an ontology ensures explicit axiomatization of the model structure enabling access to data and their associated semantic. Moreover, ontologies enable interactions with the database by referring to knowledge rather than ad hoc table, field structure and naming. Consequently, data storage, formulation and calculation of queries can be more systematic and reliable.
The presented method differs from other approaches involving mapping ontologies and databases described in the literature. Namely, the goal is not to create an ontology from source databases or to store the ontology in a database. Instead, the ontology objectively captures the domain's semantic rather than the database's structure. In this way, the resulted RDB reflects the ontology and explicitly ties it with the data. Also, the method does not convert data into a triple store (Resource Description Framework [RDF] triples) as it would not work in the use case of interest where the actors require a relational endpoint for data integrity reasons. Nevertheless, if a process benefits from transforming data from an RDB into a triple store, the work presented here would still greatly facilitate and simplify this task.
This article presents a method for deriving a relational data model from an ontology using conversion rules that covers more ontological constructs compared with existing methods including axiom complexity reduction rules, an implementation, OntoRelα, a freely available prototype used to demonstrate the conversion rules on various ontologies, a use case, a brief survey of existing methods, and a highlight of the contributions and remaining challenges.
Objective
Many limitations remain with the existing methods to derive a sharable and interoperable relational data model based on a knowledge model for a heterogeneous environment. More specifically, every relational construct must be derived from a specific ontological construct uniformly in the same way, to reach uniformity and consistency through data integrity checks. Moreover, the generated data model must not reflect decisions based on specific query requirements to allow data usage outside the source database's scope or a specific project. Consequently, the standardization and automation of the conversion through a set of rules increase the relevance and consistency of the derived relational data model and reduce the risk of errors and ambiguities that might be unnoticeably introduced by choices influenced by undocumented aspects of the designers' reality. The objective is to address the gaps found in the literature regarding ontological construct coverage, including complex axioms found in biomedical ontologies, and to offer a publicly available implementation. Thus, this article presents an advanced conversion method and accessible implementation that handles more ontological constructs and complex axioms.
Method
An ontology is constructed using classes, individuals, axioms, properties (object properties and data properties), cardinality restrictions, datatypes, and annotations. 11 12 A relational model is constructed by a set of relations defined by attributes (pairs of a unique name and a datatype), tuples, constraints, and functions. 13 14 Both models share common foundations: the set theory and the first-order logic. Thus, at least in part, a conversion from one to the other is possible.
The distinctive characteristic of the presented method is that it is automated using uniform and consistent conversion rules to capture the richness of the ontology. As a result, the derived relational data model is shareable and interoperable and is practical for storing heterogeneous health data for various applications. The conversion rules must include an axiom complexity reduction process and generate a highly normalized relational schema to minimize data redundancy and potential contradictions. The following illustrates a set of conversion rules with examples presented by ontology constructs. A complete example can be found in Appendix C.
Conversion Rules
Class [C] is a set of individuals (also known as. instances). A class is converted to a relation that includes an Individual Identifier attribute ( classIri_iid:iid_type ) used as a primary key (see Fig. 1 ). Each value of iid uniquely identifies an individual. The class Thing (the superclass of all classes) may be converted to a relation with one attribute, the iid . Thus, the relation Thing contains all individual identifiers of the database. This conversion makes it possible to define an independent artificial key to index individuals.
Object Property [op] links two individuals. An object property is converted to a relation including two iid attributes (see Fig. 2 ): the subject ( subject_iid:iid_type ) and the object ( object_iid:iid_type ). This conversion allows direct access to the links between the data of two relations and allows to store links that are not explicitly specified by an axiom of the ontology.
Property inheritance axiom [p 0 ⊑ p 1 ] defines an inheritance between two properties. A property inheritance axiom is converted into an “isa” referential key from the sub-property relation to the super-property relation (see Fig. 3 ). A referential key in a relational data model links two relations (see Fig. 4 ). This conversion ensures data integrity by preserving the taxonomy of the properties.
Class inheritance axiom [C 0 ⊑ C 1 ] defines an inheritance between two classes. A class inheritance axiom is converted into an “isa” referential key from the subclass relation to the superclass relation. This conversion ensures data integrity by preserving the taxonomy of the classes.
Class association axiom [C 0 op qt C 1 ] defines an association between individuals belonging to two classes according to an object property and a quantifier. An object property [op] links two individuals. A quantifier [qt] is an interval of integers that specifies the association's cardinality in which individuals can participate. A class association axiom is converted into an association relation (a relation related to two other relations) with two attributes, the primary key of both associated class relations (see Fig. 5 ). The primary key of the association relation is composed of both attributes. Moreover, three object property referential keys are defined from the association relation to the primary key of each associated class relation and property relation. Also, if qt.min > 0 and qt.max ∈ N, a quantification constraint is defined to check the number of individuals according to the quantification specified in the axiom. This conversion controls data integrity by ensuring that all the tuples in the relation have the same predicate with respect to the quantifier.
Datatype [D] is a constrained set of values. A datatype is converted into an SQL user-defined type reused to specify the data attributes uniformly. For example, the OWL xsd:String is converted to CREATE DOMAIN “xsd:String” AS TEXT (in the PostgreSQL syntax). This conversion maintains the datatype definition uniformly across all the relations.
Data association axiom [C 0 dp qt D 1 ] defines an association between each individual of a class [C 0 ] and a value of a datatype [D 1 ] according to a data property [dp] and a quantifier. A data property links an individual to a value. A data association axiom is converted into a data relation with two attributes (see Fig. 6 ): the primary key of the class relation and a data attribute. The data relation's primary key is composed of both attributes. One data property referential key is defined from the data relation to the class relation. This conversion controls data integrity by avoiding redundancy and missing information.
Individual [I] is an entity of the modeled reality. An individual is converted into a tuple inserted into the proper relations according to the class of the individual (see Fig. 7 ). It is strongly recommended that iid attribute values be automatically generated (e.g., Globally Unique Identifier [GUID]), allowing independent individual indexing and automatically propagating values into the relations.
Annotation describes an aspect of an ontological construct with a text in a specific natural language. An annotation is used to document the database and to provide multiple access interfaces in different languages using views. A definition annotation is converted to SQL comment so they can be integrated into the RDBMS catalog (if the target RDBMS supports it). This conversion allows the documentation of relational constructs within the schema.
Axiom Complexity Reduction
An ontological axiom can be defined using different expressions that are logically equivalent. It follows that a considerable number of cases must be considered when dealing with axioms such as complex axioms. A complex axiom is an expression formed with multiple expressions connected using a conjunction (AND) or a disjunction (OR) operation. Complex axioms must be reduced into a simpler form to ensure a rigorous conversion into predictable and consistent relational constructs. Thus, axiom complexity reduction functions are defined. The complexity reduction consists of generating a set of simple axioms from a set of complex axioms. To simplify an axiom, each expression in the complex axiom is replaced by a new uniquely named class derived according to a set of rules. To simplify an ontology, the process is applied recursively until all axioms are simplified. Each expression in an axiom is syntactically analyzed using the abstract grammar and reduced recursively according to reduction rules until a set of simple axioms is reached. More formal details can be found in Appendix B.
Here is a concrete didactic example of a subset of the PDRO, 15 an ontology about drug prescriptions, with one complex axiom (in bold).
After the axiom complexity reduction, the resulted ontology is as follows:
which can be derived into the following relational schema (see Fig. 8 ).
Results
To illustrate the feasibility and the applicability of the presented method, a prototype, OntoRelα, was developed. As an input, OntoRelα takes an OWL ontology and some configuration files. It outputs an RDB script for the PostgreSQL database, a list of warnings to notify the user of problems in the conversion process, a mapping catalog between each ontological construct and relational construct (named OntoRelCat), and a normalized version of the ontology after the axiom complexity reduction. The resulted RDB scripts can be executed on PostgreSQL v9.6 + . A small example of the human body mass from the physiological measurement ontology is presented in Appendix C.
The method is implemented through multiple processes (see Fig. 9 ):
The analysis process creates an instance of the normalized ontology model (µOnto) using a source ontology and an ontology configuration file that parameterizes the process.
The µOnto generator process generates a normalized ontology with reduced axioms formalized according to the µOnto language.
The conversion process converts an instance of µOnto into an ontological–relational model (OntoRel) according to the relational model (µRel) using the RDB configuration file that parameterizes the process.
The OntoRelCat generator process generates the definitions of construct in the OntoRel to build a human and machine-readable mapping catalog.
The SQL generator process generates a set of SQL scripts to build the RDB.
Many open-source libraries were used to implement the processes and the internal data structure: OWLAPI 5.1 a to load and analyze the ontology in OWL format; JGraphT b to create graphs for the ontology and the database; Snakeyaml c to analyze the configuration files in YAML format; StringTemplate d for code generation and Jackson e to generate JSON files for OntoRelCat.
The prototype was tested with various ontologies (especially the Genotype Ontology, Fanconi Anemia Ontology, Ontology of Adverse Events, and the Prescription of Drugs Ontology) of different sizes. Also, the resulted relational data model was used in different use cases of the Quebec SPOR Support Unit and the SPOR Canadian data platform. 16 The prototype and detailed results, including the RDB scripts, can be found on GitHub: https://github.com/OpenLHS/OntoRela .
Use Case
Software used to record clinical data generally does not provide explicit semantic to enable secondary use of data without ambiguity. In addition, there is currently no national standard for data exchange across institutions and provinces in Canada. This use case illustrates the context of drug prescriptions where researchers or physicians need to extract information about drug and laboratory prescriptions to make appropriate follow-up or identify inappropriate or missing prescriptions. Users are faced with many challenges, including and not limited to heterogeneity in levels of generality in drug administration and dispensing specification, homonymy, and dosing instructions. 15 Moreover, merging data of drugs and laboratory results stored in different databases is not a straightforward task.
PDRO, 15 an ontology about drug prescriptions, is used to illustrate this use case with examples. OntoRelα generates the relational data model, and the database can be populated from data sources using Extract–Load–Transform processes or mediation systems. In this way, one query suffices to obtain needed data at various levels of generality without the need to explore each source separately to understand the content.
Consider parts of two drug prescriptions termed “Drug administration specification” (DAS) and “Drug dispensing specification” (DDS) written on a paper or stored in a nonstandard database:
(DAS1) “Metoprolol 50 mg PO bid” instructs taking Metoprolol 50 mg per mouth (PO) twice a day (bid),
(DDS1) “Apo-Metoprolol 50 mg tab, 1 tab PO bid” instructs taking one tab of Apo-Metoprolol 50 mg per mouth twice a day.
With DAS1, most clinicians would intend to prescribe the active ingredient “Metoprolol” rather than a specific drug product name manufactured by a specific company like “Apo-Metoprolol” because all pharmacies do not have in inventory every possible brand. However, DDS1 does refer to such a specific pharmaceutical product. Moreover, even strings that are identical in their composition and order of characters may have different meanings. For example, “Metoprolol” in DAS1 would usually refer to any drug product containing metoprolol or to the active ingredient metoprolol itself, although it might refer to the generic drug product branded with the name “Metoprolol” in some cases. Moreover, the information on the prescribed drug may differ from the dispensed drug, and more often, databases do not distinguish between them (between the DAS and the DDS).
These issues are solved using a relational data model generated from an ontology because it provides the explicit semantic of the data. The data model is illustrated in two forms: the graph form ( Fig. 10 ) and the relational form ( Fig. 11 ). Fig. 10 illustrates, as a graph, part of the generated relational data model from PDRO with data examples. The full rectangles represent a data relation containing tuples. The dotted rectangles represent a class relation with calculated tuples. The lines represent the association relations.
Fig. 11 illustrates part of the generated relational data model from PDRO with data examples.
Finally, for other use cases, the relational data model can be used as a target model to store data extracted from natural language processing or for classification using ontology reasoners.
Related Work
The literature suggested several methods to derive a relational data model from an ontology. A literature review was conducted in mid-2018 to explore methods published after 2010 describing RDB generation from an ontology. 17 A list of 23 criteria was defined to evaluate and compare the 10 most relevant papers.
The present article extends this review with recent publications and criterion coverage details (see Appendix A). The evaluated papers: A1.Dou.2010, 18 A2.Bellatreche.2010, 19 A3.Saccol.2011, 20 A4.Vyšniauskas.2012, 21 A5.Hornung.2013, 22 A6.Podsiadły-Marczykowska.2014, 23 A7.Jiménez-Ruiz.2015, 24 A8.Ho.2015, 25 A9.Afzal.2016, 26 A10.Achpal.2016, 27 A11.Mahmudi.2018 28 and A12.Guidoni.2020. 29
The evaluated methods differ in several ways: the ontology constructs considered during the conversion, the completeness of the generated relational model, and the availability of tools that implement the method. As expected, all the methods convert a class into a relation with a primary key. Regarding axioms, complex ones are never considered nor handled, which is a significant issue for biomedical ontologies. Simple ones follow two dominant approaches: they are converted into an attribute or into a relation. Converting an axiom into an attribute may introduce several issues, such as missing information (nulls) for zero-to-one or zero-to-many relationships and data redundancy for many-to-many relationships. Converting an axiom into a relation may impact the query performance, but this is a better approach to guarantee data integrity and structure extension, as performance can be handled at the physical level by the RDB management systems using adequate indexing structure. 30 These axiom conversions and the inability to deal with complex axioms reduce the structural uniformity across all the relations in the data model and increase semantic loss.
Moreover, the review outlined limitations in different areas which may lead to semantic loss, including the lack of conversion rules for object properties, property inheritance axioms, cardinality restriction, property characteristics, and annotation, as well as the inability to process complex axioms (set of simple expressions linked with logical operators) that are widely used in biomedical ontologies. Most methods store some important ontological constructs into metadata tables and do not derive explicit structure or constraints from them. As a result, the axiom verification will be incomplete or challenging to automate. Thus, the main challenge is maintaining the richness of ontological definitions in the resulting relational data model by converting uniformly and consistently ontology constructs into relational constructs to detect the data that do not conform to the axioms.
Finally, only two implementations are publicly available, the first one is accessible through a web page, 22 but the source code is not available to be used and extended by other researchers. The second works with ontology defined using OntoUML based on UFO (Unified Foundational Ontology) 29 and allows defining ontologies using a graphical interface. However, defining and maintaining large biomedical ontologies using a graphical interface are not always convenient. Therefore, a more generic method is needed to benefit from the mature ontologies already in the OBO Foundry.
Contribution and Future Work
This work aimed to address the problem of designing a sharable and interoperable relational data model not only to store data coming from heterogeneous systems but also to store the associated semantic to support various applications. The method described in this article offers an advanced conversion process to enable the automatic generation of the uniform relational data model with constraints to maximize semantic preservation and control data integrity. More specifically, the presented method differs from the existing ones by the following features:
The axiom complexity reduction allows a concise and uniform conversion.
The normalization of the data model increases automation and uniformity.
The generation of advanced constraints such as quantification, intersection, and union using functions increases data integrity control.
The transformation of ontological annotations into SQL comments and views provides documentation and multiple access points within the data model.
The configurable transformation of OWL types into SQL types allows a uniform usage of OWL types.
The generation of a mapping dictionary enables structure reversibility and data extraction in various output formats.
The implementation, OntoRelα, can be used with various OWL ontologies and PostgreSQL databases.
However, several limitations will require further work. First, the relatively large size of the resulting relational data model is a challenge, especially when trying to interact manually with the model. As an example, to get all the data related to a drug prescription, we need to build a query with at least 16 joints (see Fig. 11 ). This limitation could be alleviated by using navigation tools and query builder applications fully leveraging this new approach to benefit from the full semantic while helping the user find the needed construct faster. Second, structural redundancy in the data model is caused by redundant axioms. Advanced axiom redundancy reduction rules are already under development to address this, yielding a smaller RDB while fully preserving its semantic. Finally, more conversion rules are being defined to improve the data integrity and data ingestion, such as deriving secondary keys, general constraints using property characteristics, 24 27 and generating data modification procedures 27 to ensure data quality.
Conclusion
Many conversion methods from an ontology to a relational data model have already been proposed. However, these propositions suffer from limitations regarding the coverage of ontological constructs, the handling of complex axioms, and the accessibility of tools. This article presented conversion rules and a freely available prototype named OntoRelα that covers more ontological constructs and handles complex axioms, and that can be used and extended by other researchers. This work is a first step toward building a tool to generate a sharable and interoperable database using ontologies. More development is underway to refine the derived relational data model and provide complementary data access tools.
Appendices
Appendix A
This section presents the 23 criteria defined to evaluate and compare the 12 most relevant papers against our method.
Criterion Application by Method
Table 1 presents the comparison criteria applicable to each compared paper. A criterion is fulfilled by the method (X), not fulfilled (–), or unknown (?). For example, for A1, the criterion “Ontology language” is unknown, “Domains” are not fulfilled, and “Primary Keys” are fulfilled. Also, the count of fulfilled criteria is calculated for each method. OntoRelα fulfills 16 criteria over 23. To address the remaining criteria, this article introduces an advanced analysis of the ontology (1) to extract property characteristics and datatype constraints, (2) to generate modification procedures for data that verify integrity constraints, and (3) to implement the individual and tuple reversibility algorithm.
Table 1. Criterion application by method [fulfilled (X), not fulfilled (–), unknown(?)] a .
A1 18 | A2 19 | A3 20 | A4 21 | A5 22 | A6 23 | A7 24 | A8 25 | A9 26 | A10 27 | A11 28 | A12 29 | OntoRelα | |
---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Ontology | |||||||||||||
Ontology language | ? | ? | ? | ? | X | X | X | ? | X | X | ? | – | X |
Schema | |||||||||||||
Structure | ? | X | – | X | X | – | X | ? | ? | ? | ? | X | X |
Domains | – | – | – | – | – | – | – | – | – | – | – | – | X |
Primary keys | X | X | X | X | X | X | X | X | X | X | ? | X | X |
Secondary keys | – | ? | – | X | ? | ? | X | ? | ? | X | ? | – | X |
Foreign keys | ? | X | X | X | X | X | X | X | X | X | X | X | X |
Participation constraint | ? | ? | – | – | – | – | X | – | – | X | ? | ? | X |
General constraint | ? | ? | X | X | ? | X | X | X | – | X | ? | X | – |
Modification procedure | – | – | – | – | – | – | – | – | – | X | ? | – | – |
Target DBMS | ? | ? | X | ? | ? | X | ? | X | X | ? | ? | ? | X |
Process | |||||||||||||
Axiom reduction | ? | ? | – | ? | ? | – | – | ? | ? | ? | – | ? | X |
Intermediate structure | – | X | – | X | – | – | ? | X | X | ? | ? | X | X |
Type conversion | ? | ? | – | ? | ? | ? | X | X | X | ? | ? | ? | X |
Restriction conversion | ? | X | – | X | – | – | X | X | X | X | ? | ? | X |
Individual conversion | X | – | – | – | X | – | X | X | – | X | X | ? | – |
Annotation conversion | – | – | – | X | X | – | – | – | – | – | ? | – | X |
Structural reversibility | X | X | – | X | – | ? | – | X | X | ? | – | ? | X |
Tuple reversibility | X | X | – | X | X | ? | X | ? | ? | ? | – | ? | – |
Tool | |||||||||||||
Implementation | X | X | X | X | – | X | X | X | X | ? | X | X | X |
Availability | – | ? | ? | – | X | ? | – | ? | ? | ? | ? | X | X |
Total (X) | 5 | 7 | 5 | 10 | 8 | 6 | 12 | 9 | 8 | 9 | 9 | 7 | 16 |
Extended with permission from Khnaisser C, Lavoie L, Burgun A, Ethier JF. Generating relational database using ontology review: issues, challenges and trends. Int J Adv Comput Sci Appl. 2018;9(6):139–145.
The evaluated papers: A1.Dou.2010, 18 A2.Bellatreche.2010, 19 A3.Saccol.2011, 20 A4.Vyšniauskas.2012, 21 A5.Hornung.2013, 22 A6.Podsiadły-Marczykowska.2014, 23 A7.Jiménez-Ruiz.2015, 24 A8.Ho.2015, 25 A9.Afzal.2016, 26 A10.Achpal.2016, 27 A11.Mahmudi.2018 28 and A12.Guidoni.2020 29 .
Criteria Definition
Here is the list of criterion definitions used to compare each method:
-
Ontology
– Ontology language—the ontology language supported by the method: OWL-DL, OWL-QL, OWL-RL, OWL- EL, RDF(S), DAML, etc.
-
Schema
– Structure—the relational schema normal form: 3NF, BCNF, 5NF, or 6NF. This criterion can be deduced from the conversion rules.
– Domains—does the method convert the ontology data types and their constraints into domains (e.g., CREATE DOMAIN in PostgreSQL)?
– Primary keys—does the method generate [G] or calculate [C] the primary keys?
– Secondary keys—does the method generate the secondary key from the set of axioms?
– Foreign keys—does the method convert the appropriate axioms into foreign keys?
– Participation constraints—does the method convert cardinalities into constraints?
– General constraints—does the method convert datatype and disjoint constraints into general constraints?
– Modification procedures—does the method define the procedures for modifying the data (insert, delete, and update triggers)?
– Target RDBMS—such as PostgreSQL, MySQL, Oracle, MSSQL, etc.
-
Process
– Axiom reduction—does the conversion process deal with complex axioms?
– Intermediate structure—the intermediate data structure used to convert OWL into a relational schema: MOF (Meta-Object Facility), FOL (First-order logic), RDF, Jena model, etc.
– Type conversion—does the conversion process specify or configure the conversion rules between ontology types and SQL types?
– Restriction conversion—does the conversion process convert the restrictions to general constraints?
– Annotation conversion—does the conversion process convert the annotations to document the relational schema?
– Structural reversibility—does the conversion process make it possible to refer to the ontology construct? Furthermore, does the method describe the algorithm and propose an implementation of structural reversibility?
– Tuple reversibility—does the conversion process make it possible to import tuples stored in the DB in their full ontological expression? Furthermore, does the method describe the algorithm and propose an implementation of tuple reversibility?
-
Tool
– Implementation—has the method been implemented?
– Availability—is the tool publicly available?
Appendix B
Each expression in an axiom is syntactically analyzed using the abstract grammar and reduced recursively according to reduction rules until a set of simple axioms is reached.
axiom::= domain operator range
domain::= expression
range::= expression
expression::= ID
| expression ('⊔' | '⊓') expression
| property
property::= '(' operator expression ')'
operator::= '⊑' | propertyOperator | qt
propertyOperator::= ID
qt::= '[' N '..' N ']'
N::= /* positive or null integer */
ID::= /* an identifier (e.g., IRI)*/
The reduction is achieved through the function Ф with three components: Ф 1 , Ф 2 , and Ф 3 . All the components take as an input an axiom.
Ф 1 returns the class representing the concept (it can be the same class or a class not defined in the original ontology).
Ф 2 returns a set of constraints that must be guaranteed to preserve the semantic validity.
Ф 3 returns a set of new reduced axioms produced by Ö that replaces the input axiom.
The reduction function Ф is defined by recursion regarding the four types of expressions of an axiom as follows:
where
A is an ID of a class.
Ź is the ID new generated new class.
β and ᵧ are expressions as defined in the grammar.
Therefore, the reduction produces a set of new classes, axioms, and constraints calculated by Ф. The new axioms are all derivable by the grammar and have the following final simple form {axiom::= ID operator ID}.
Appendix C
The example in Figure 12 shows a sample of physiological measurement ontology, the human body mass. The code below presents some ontological constructs in a simplified syntax, and the figures below, Figure 12 and Figure 13 , illustrate the generated relational data model as a graph and as a relation schema respectively. The complete example can be found on GitHub: https://github.com/OpenLHS/OntoRela .
Acknowledgments
The authors would like to acknowledge the financial support of Fonds de recherche du Québec - Nature et technologie , Unité de Soutien SRAP du Québec, and the Health Data Research Network Canada. They also would like to thank the development team of Groupe de recherche interdisciplinaire en informatique de la santé .
Conflict of Interest None.
Ethical Considerations
This research does not involve human subjects.
OP “has part”
OP “has measurement unit label”
DP “has specified numeric value”
CLASS “Rate of administration specification”
ISA “Information content entity”
“has part” [1..1] (“Mass per time value specification” OR “Volumetric flow rate value specification”)
CLASS “Mass per time value specification”
ISA “Scalar value specification”
“has measurement unit label” [1..1] “Mass per time unit”
“has specified numeric value” [1..1] “positive rational”
CLASS “Volumetric flow rate value specification”
ISA “Scalar value specification”
“has measurement unit label” [1..1] ““Volumetric flow unit”
“has specified numeric value” [1..1] “positive rational”
CLASS “Volumetric flow unit” “has part” [1..1] “Mass unit” “has part” [1..1] “Time unit”
CLASS “Mass per time unit” “has part” [1..1] “Volume unit” “has part” [1..1] “Time unit”
CLASS “Mass unit”
ISA “Measurement unit label”
“has value” [1..1] String
CLASS “Time unit”
ISA “Measurement unit label”
“has value” [1..1] String
CLASS “Volume unit”
ISA “Measurement unit label”
“has value” [1..1] String
CLASS “Mass per time value or Volumetric flow rate value specification”
CLASS “Rate of administration specification”
ISA “Information content entity”
“has part” [1..1] “Mass per time value or Volumetric flow rate value specification”
CLASS “Mass per time value specification”
ISA “Scalar value specification”
ISA “Mass per time value or Volumetric flow rate value specification”
“has measurement unit label” [1..1] “Mass per time unit”
“has specified numeric value” [1..1] “positive rational”
CLASS “Volumetric flow rate value specification”
ISA “Scalar value specification”
ISA “Mass per time value or Volumetric flow rate value specification”
“has measurement unit label” [1..1] “Volumetric flow unit”
“has specified numeric value” [1..1] “positive rational”
ONTOLOGY”:humanbodyweight-example.owl”
PROPERTY”:BFO_0000050” LABEL @en 'part of'
PROPERTY”:BFO_0000051” LABEL @en 'has part'
PROPERTY: “IAO_0000039” LABEL @en 'has measurement unit label'
ISA”:BFO_0000051”
PROPERTY”:IAO_0000136” LABEL @en 'is about'
PROPERTY”:IAO_0000219” LABEL @en 'denotes'
ISA”:IAO_0000136”
PROPERTY”:OBI_0000299” LABEL @en 'has_specified_output'
PROPERTY”:OBI_0000312” LABEL @en 'is_specified_output_of'
PROPERTY: “OBI_0001938” LABEL @en 'has value specification'
PROPERTY”:RO_0000057” LABEL @en 'has participant'
PROPERTY”:PHYSIO_0000089” LABEL @en 'has evaluant'
ISA”:RO_0000057”
PROPERTY”:IAO_0000004” LABEL @en 'has measurement value'
PROPERTY”:PHYSIO_0000100” LABEL @en 'has value'
CLASS”:PHYSIO_0000083”LABEL @en'physiological evaluation report'
”:BFO_0000051” [1..1]”:HADO_0000006”
”:BFO_0000051” [1..*]”:PHYSIO_0000093”
CLASS”:PHYSIO_0000085” LABEL @en 'physiological evaluation'
”:PHYSIO_0000089” [1..1]”:OBI_0100026”
CLASS”:PHYSIO_0000093” LABEL @en 'physiological data item'
ISA”:IAO_0000027”
CLASS”:PHYSIO_0000008” LABEL @en 'body weight measurement process'
ISA”:PHYSIO_0000085”
CLASS”:PHYSIO_0000065” LABEL@en'human body mass measurement datum'
ISA”:IAO_0000032”
ISA”:PHYSIO_0000093”
”:OBI_0000312” [1..*]”:PHYSIO_0000008”
CLASS”:IAO_0000027” LABEL @en 'data item'
CLASS”:IAO_0000109” LABEL @en 'measurement datum'
ISA”:IAO_0000027”
”:IAO_0000039” [1..1]”:IAO_0000003”
CLASS”:IAO_0000032” LABEL @en 'scalar measurement datum'
ISA”:IAO_0000109”
”:OBI_0001938” [1..*]”:OBI_0001931”
”:IAO_0000004” [1..1]”:double”
CLASS”:OBI_0001931” LABEL @en 'scalar value specification'
CLASS”:IAO_0000003” LABEL @en 'measurement unit label'
”:PHYSIO_0000100” [1..1]”:string”
CLASS”:UO_0000002” LABEL @en 'mass unit'
ISA”:IAO_0000003”
CLASS”:HADO_0000008” LABEL @en 'patient'
ISA”:NCBITaxon_9606”
CLASS”:HADO_0000006” LABEL @en 'medical record identifier'
”:IAO_0000219” [1..1]”:ONTORELA_C0025X”
CLASS”:OBI_0100026” LABEL @en 'organism'
CLASS”:NCBITaxon_9606” LABEL @en 'Homo sapiens'
ISA: “OBI_0100026”
CLASS”:ONTORELA_C0025X”
LABEL @en ' health care record is about patient'
ISA”:PHYSIO_0000094”
”:IAO_0000136” [1..*]”:HADO_0000008”
CLASS”:PHYSIO_0000094” LABEL @en 'health care record'
References
- 1.Calvanese D, De Giacomo G, Lembo D, Lenzerini M, Rosati R, Ruzzi M.Using OWL in data integrationIn: de Virgilio R, Giunchiglia F, Tanca L, eds. Semantic Web Information Management: A Model-Based Perspective.Berlin Heidelberg: Springer; 2010397–424. [Google Scholar]
- 2.Pacaci A, Gonul S, Sinaci A A, Yuksel M, Laleci Erturkmen G B. A semantic transformation methodology for the secondary use of observational healthcare data in postmarketing safety studies. Front Pharmacol. 2018;9:435. doi: 10.3389/fphar.2018.00435. [DOI] [PMC free article] [PubMed] [Google Scholar]
- 3.Spanos D E, Stavrou P, Mitrou N. Bringing relational databases into the semantic web: a survey. Semant Web. 2012;3(02):169–209. [Google Scholar]
- 4.Khouri S, Bellatreche L, Jean S, Ait-Ameur Y.Requirements driven data warehouse design: we can go furtherIn: 6th International Symposium on Leveraging Applications of Formal Methods, Verification and Validation, ISoLA 2014, October 8–11, 2014. Vol 8803. Lecture Notes in Computer Science (including subseries Lecture Notes in Artificial Intelligence and Lecture Notes in Bioinformatics).Berlin: Springer Verlag; 2014588–603.
- 5.Abello A, Romero O, Bach Pedersen T. Using semantic web technologies for exploratory OLAP: a survey. IEEE Trans Knowl Data Eng. 2015;27(02):571–588. [Google Scholar]
- 6.Bodenreider O. Biomedical ontologies in action: role in knowledge management, data integration and decision support. Yearb Med Inform. 2008:67–79. [PMC free article] [PubMed] [Google Scholar]
- 7.Santana da Silva F, Jansen L, Freitas F, Schulz S. Ontological interpretation of biomedical database content. J Biomed Semantics. 2017;8(01):24. doi: 10.1186/s13326-017-0127-z. [DOI] [PMC free article] [PubMed] [Google Scholar]
- 8.Haendel M A, Chute C G, Robinson P N. Classification, ontology, and precision medicine. N Engl J Med. 2018;379(15):1452–1462. doi: 10.1056/NEJMra1615014. [DOI] [PMC free article] [PubMed] [Google Scholar]
- 9.OBI Consortium . Smith B, Ashburner M, Rosse C. The OBO Foundry: coordinated evolution of ontologies to support biomedical data integration. Nat Biotechnol. 2007;25(11):1251–1255. doi: 10.1038/nbt1346. [DOI] [PMC free article] [PubMed] [Google Scholar]
- 10.Schuler J C, Ceusters W M. The problems of realism-based ontology design: a case study in creating definitions for an application ontology for diabetes camps. AMIA Annu Symp Proc. 2018;2017:1517–1526. [PMC free article] [PubMed] [Google Scholar]
- 11.Motik B, Patel-Schneider P F, Parsia B.OWL 2 Web Ontology Language Structural Specification and Functional-Style Syntax (Second Edition)W3C. Published 2012. Accessed April 3, 2016 at:https://www.w3.org/TR/2012/REC-owl2-syntax-20121211/
- 12.Baader F.The Description Logic Handbook: Theory, Implementation, and Applications2nd ed., paperback ed.Cambridge: Cambridge University Press; 2010 [Google Scholar]
- 13.Codd E F. Boston: Addison-Wesley Longman Publishing Co., Inc.; 1990. The Relational Model for Database Management: Version 2. [Google Scholar]
- 14.Darwen H, Date C J. The third manifesto. SIGMOD Rec. 1995;24(01):39–49. [Google Scholar]
- 15.Ethier J F, Barton A, Taseen R. An ontological analysis of drug prescriptions. Appl Ontol. 2018;13(04):273–294. [Google Scholar]
- 16.Dahl L T, Katz A, McGrail K. The SPOR-Canadian Data Platform: a national initiative to facilitate data rich multi-jurisdictional research. Int J Popul Data Sci. 2020;5(01):1374. doi: 10.23889/ijpds.v5i1.1374. [DOI] [PMC free article] [PubMed] [Google Scholar]
- 17.Khnaisser C, Lavoie L, Burgun A, Ethier J F. Generating relational database using ontology review: issues, challenges and trends. Int J Adv Comput Sci Appl IJACSA. 2018;9(06):139–145. [Google Scholar]
- 18.Dou D, Qin H, Lependu P. OntoGrate: towards automatic integration for relational databases and the semantic web through an ontology-based framework. Int J Semant Comput. 2010;04(01):123–151. [Google Scholar]
- 19.Bellatreche L, Ait-Ameur Y, Chakroun C. A design methodology of ontology based database applications. Log J IGPL. 2010;19(05):648–665. [Google Scholar]
- 20.Saccol DdB, Andrade TdC, Piveta EK. Mapping OWL ontologies to relational schemas Paper presented at: 2011 IEEE International Conference on Information Reuse Integration;201171–76.
- 21.Vyšniauskas E, Nemuraitė L, Paradauskas B. Preserving semantics of Owl 2 ontologies in relational databases using hybrid approach. Inf Technol Control. 2012;41(02):103–115. [Google Scholar]
- 22.Hornung T, May W.Experiences from a TBox reasoning application: deriving a relational model by OWL schema analysisIn: Rodriguez-Muro M, Jupp S, Srinivas K, eds. Proceedings of the 10th International Workshop on OWL: Experiences and Directions (OWLED 2013) Co-Located with 10th Extended Semantic Web Conference (ESWC 2013), Montpellier, France, May 26–27, 2013; Vol 1080. CEUR Workshop Proceedings. CEUR-WS.org; 2013. Accessed February 9, 2018 at:http://ceur-ws.org/Vol-1080/owled2013_3.pdf
- 23.Podsiadły-Marczykowska T, Gambin T, Zawiślak R.Rule-based algorithm transforming OWL ontology into relational databaseIn: Beyond Databases, Architectures, and Structures. Communications in Computer and Information Science.Cham: Springer; 2014148–159. [Google Scholar]
- 24.Jiménez-Ruiz E, Kharlamov E, Zheleznyakov D.BootOX: practical mapping of RDBs to OWL 2In: The Semantic Web - ISWC 2015.Cham: Springer; 2015113–132. [Google Scholar]
- 25.Ho L TT, Tran C PT, Hoang Q.An approach of transforming ontologies into relational databasesIn: Intelligent Information and Database Systems.Cham: Springer; 2015149–158. [Google Scholar]
- 26.Afzal H, Waqas M, Naz T. OWLMap: fully automatic mapping of ontology into relational database schema. Int J Adv Comput Sci Appl. 2016;7(11):7–15. [Google Scholar]
- 27.Achpal A, Bannihatti Kumar V, Mahesh K.Modeling ontology semantic constraints in relational database management systemIn: Proceedings of the International MultiConference of Engineers and Computer Scientists; 2016. Accessed February 15, 2018 at:https://www.researchgate.net/publication/296437737_Modeling_Ontology_Semantic_Constraints_in_Relational_Database_Management_System
- 28.Mahmudi K, Liem M MI, Akbar S. Ontology to relational database transformation for web application development and maintenance. J Phys Conf Ser. 2018;971(01):12031. [Google Scholar]
- 29.Guidoni G L, Almeida J PA, Guizzardi G.Transformation of ontology-based conceptual models into relational schemasIn: Dobbie G, Frank U, Kappel G, Liddle SW, Mayr HC (eds). Conceptual modeling. ER 2020. Lecture notes in computer science(), vol 12400. Springer, Cham.https://doi.org/10.1007/978-3-030-62522-1_232020
- 30.Abadi D J, Marcus A, Madden S R, Hollenbach K. SW-Store: a vertically partitioned DBMS for Semantic Web data management. VLDB J. 2009;18(02):385–406. [Google Scholar]