Please use this identifier to cite or link to this item: https://hdl.handle.net/10316/107953
DC FieldValueLanguage
dc.contributor.advisorCabral, Bruno Miguel Brás-
dc.contributor.advisorSeverance, Charles-
dc.contributor.authorSilva, Henrique Tavares-
dc.date.accessioned2023-08-02T22:04:19Z-
dc.date.available2023-08-02T22:04:19Z-
dc.date.issued2023-07-20-
dc.date.submitted2023-08-02-
dc.identifier.urihttps://hdl.handle.net/10316/107953-
dc.descriptionDissertação de Mestrado em Engenharia Informática apresentada à Faculdade de Ciências e Tecnologia-
dc.description.abstractThis thesis aims to study database portability in the context of the large, enterprise legacy code that is Sakai LMS, which is a free, community-source, educational software platform designed to support teaching and research, and has beenunder continuous development and production for the past 20 years.The application is committed to database portability and currently supports Oracle and MySQL and wishes to support PostgreSQL going forward. The application mixes hand-constructed SQL, templated SQL, and data persistence by a JavaORM solution, JPA. The goal is not to rewrite the application to use a new wayto generate SQL but to look at the effort required to convert all SQL approachesfrom one dialect to another.To inform and help accomplish this engineering task, this thesis will have a deeperexamination of how the application executes all database-related operations andexplore how the SQL dialects diverge among the various databases. This paperwill also look at strategies to add a new database dialect or convert SQL from onedialect to another, exploring the jOOQ library and then testing its effectiveness inthis internship’s problem.This thesis work contributed to the progress in the challenge of inserting the PostgreSQL dialect into SakaiLMS:• Sakai LMS can now start up with a PostgreSQL database, using a MySQLSQL service that gets translated to Postgres.• The proposal of an architecture that can build the base for a translationsserver that enables Sakai LMS to be fully compatible with Postgres and,thanks to the way jOOQ’s SQL translator works, other relational databases,without modifying the SQL service.In addition to that, this work also allowed us to conclude that jOOQ’s SQL translator works for most translations, but not always. So it’s necessary to modifyany jOOQ SQL translator layer to cope with the errors it throws. As we couldconclude, manual edition and approval of unsuccessful translations are enough.Another conclusion taken was that the SQL service in Sakai isn’t the only entityresponsible for executing SQL statements in Sakai. This turned out to be a limitation in the work’s results because the proposed architecture wasn’t expectingthat behavior from Sakai.eng
dc.description.abstractEsta tese tem como objetivo estudar a portabilidade de bases de dados no contexto de large, enterprise legacy code que é o Sakai LMS, que é uma plataforma de software educacional gratuita, de código aberto, projetada para apoiar o ensino e a pesquisa, e tem sido alvo de contínuo desenvolvimento e produção nos últimos 20 anos.A aplicação está comprometida com a portabilidade de bases de dados e atualmente suporta Oracle e MySQL e deseja oferecer começar a suportar PostgreSQL. A aplicação combina SQL construído manualmente, SQL modelado e persistência de dados por uma solução ORM em Java, JPA. O objetivo não é reescrever a aplicação para usar uma nova maneira de gerar SQL, mas observar o esforço necessário para converter todas as abordagens de SQL de um dialeto para outro.Para informar e ajudar a realizar esta tarefa de engenharia, esta tese examinará de como a aplicação executa todas as operações relacionadas com a sua base de dados e explorar como os dialetos SQL divergem entre as várias bases de dados. Este trabalho também averiguará estratégias para adicionar um novo dialeto de banco de dados ou converter SQL de um dialeto para outro, explorando a biblioteca jOOQ e testando sua eficácia no problema deste estágio.O trabalho desta tese contribuiu para o avanço no desafio de inserir o dialeto PostgreSQL em Sakai LMS:• Sakai LMS agora pode inicializar com uma base de dados PostgreSQL, usando o serviço de SQL em MySQL que é traduzido para PostgreSQL.• A proposta de uma arquitetura que possa servir de base para um servidor de tradução que permita Sakai LMS ser totalmente compatível com PostgreSQL e, graças ao funcionamento do tradutor de SQL do jOOQ, outros bancos de dados relacionais, sem modificar o serviço de SQL.Além disso, este trabalho também nos permitiu concluir que o tradutor SQL do jOOQ funciona para a maioria das traduções, mas não sempre. Portanto, é necessário modificar qualquer camada com o tradutor de SQL do jOOQ para lidar com os erros que este gera. Como pudemos concluir, a edição manual e a aprovação de traduções malsucedidas são suficientes.Outra conclusão tirada foi que o serviço de SQL em Sakai não é a única entidade responsável pela execução de instruções SQL em Sakai. Isso acabou sendo uma limitação nos resultados do trabalho, pois a arquitetura proposta não esperava esse comportamento na aplicação.por
dc.language.isoeng-
dc.rightsopenAccess-
dc.rights.urihttp://creativecommons.org/licenses/by/4.0/-
dc.subjectSakai LMSpor
dc.subjectPostgreSQLpor
dc.subjectMySQLpor
dc.subjectOraclepor
dc.subjectjOOQ, tradução de SQLpor
dc.subjectSakai LMSeng
dc.subjectPostgreSQLeng
dc.subjectMySQLeng
dc.subjectOracleeng
dc.subjectjOOQ, SQL translationeng
dc.titleDesign and implementation of a relational data model supported in Postgres Sakai Learning Management Systemeng
dc.title.alternativeDesenho e implementação de um modelo de dados relacional apoiado em Postgres para o Sakai Learning Management Systempor
dc.typemasterThesis-
degois.publication.locationApereo Foundation-
degois.publication.titleDesign and implementation of a relational data model supported in Postgres Sakai Learning Management Systemeng
dc.peerreviewedyes-
dc.identifier.tid203337956-
thesis.degree.disciplineInformática-
thesis.degree.grantorUniversidade de Coimbra-
thesis.degree.level1-
thesis.degree.nameMestrado em Engenharia Informática-
uc.degree.grantorUnitFaculdade de Ciências e Tecnologia - Departamento de Engenharia Informática-
uc.degree.grantorID0500-
uc.contributor.authorSilva, Henrique Tavares::0009-0008-6055-5776-
uc.degree.classification13-
uc.degree.presidentejuriJesus, Alexandre Daniel Borges de-
uc.degree.elementojuriCabral, Bruno Miguel Brás-
uc.degree.elementojuriLaranjeiro, Carlos Nuno Bizarro e Silva-
uc.contributor.advisorCabral, Bruno Miguel Brás-
uc.contributor.advisorSeverance, Charles-
item.openairetypemasterThesis-
item.fulltextCom Texto completo-
item.languageiso639-1en-
item.grantfulltextopen-
item.cerifentitytypePublications-
item.openairecristypehttp://purl.org/coar/resource_type/c_18cf-
Appears in Collections:UC - Dissertações de Mestrado
Files in This Item:
File SizeFormat
Tese_Henrique_Tavares_Silva.pdf1.83 MBAdobe PDFView/Open
Show simple item record

Page view(s)

78
checked on Jul 17, 2024

Google ScholarTM

Check


This item is licensed under a Creative Commons License Creative Commons