From ef451f850b4a6ffde20981fab15588fbe523f2e4 Mon Sep 17 00:00:00 2001 From: Mike Keen Date: Sun, 19 Dec 2021 14:13:01 -0500 Subject: [PATCH] feat: triggers for fts on units and projects in sqlite --- migrations/20211212200953-fulltext-search.cjs | 52 +------- ...0211219182106-sqlite-triggers-projects.cjs | 120 ++++++++++++++++++ .../20211219184405-sqlite-triggers-units.cjs | 105 +++++++++++++++ 3 files changed, 232 insertions(+), 45 deletions(-) create mode 100644 migrations/20211219182106-sqlite-triggers-projects.cjs create mode 100644 migrations/20211219184405-sqlite-triggers-units.cjs diff --git a/migrations/20211212200953-fulltext-search.cjs b/migrations/20211212200953-fulltext-search.cjs index 888de618..f8ecc8ca 100644 --- a/migrations/20211212200953-fulltext-search.cjs +++ b/migrations/20211212200953-fulltext-search.cjs @@ -4,56 +4,18 @@ module.exports = { up: async (queryInterface, Sequelize) => { if (queryInterface.sequelize.getDialect() === 'sqlite') { await queryInterface.sequelize.query(` - create virtual table projects_fts using fts5 ( - warehouseProjectId, - currentRegistry, - registryOfOrigin, - originProjectId, - program, - projectName, - projectLink, - projectDeveloper, - sector, - projectType, - coveredByNDC, - NDCLinkage, - projectStatus, - projectStatusDate, - unitMetric, - methodology, - methodologyVersion, - validationApproach, - validationDate, - projectTag, - estimatedAnnualAverageEmissionReduction, - );`); - await queryInterface.sequelize.query( - `create virtual table units_fts using fts5 ( - projectId, - buyer, - registry, - blockIdentifier, - identifier, - qualificationId, - unitType, - unitCount, - unitStatus, - unitStatusDate, - transactionType, - unitIssuanceLocation, - unitLink, - correspondingAdjustment, - unitTag, - vintageId - );`, - ); + CREATE VIRTUAL TABLE projects_fts USING fts5(projects); + `); + await queryInterface.sequelize.query(` + CREATE VIRTUAL TABLE units_fts USING fts5(units); + `); } }, down: async (queryInterface, Sequelize) => { if (queryInterface.sequelize.getDialect() === 'sqlite') { - await queryInterface.sequelize.query(`drop virtual table projects_fts;`); - await queryInterface.sequelize.query('drop virtual table units_fts;'); + await queryInterface.sequelize.query(`drop table projects_fts;`); + await queryInterface.sequelize.query('drop table units_fts;'); } }, }; diff --git a/migrations/20211219182106-sqlite-triggers-projects.cjs b/migrations/20211219182106-sqlite-triggers-projects.cjs new file mode 100644 index 00000000..b4a9f923 --- /dev/null +++ b/migrations/20211219182106-sqlite-triggers-projects.cjs @@ -0,0 +1,120 @@ +'use strict'; + +module.exports = { + up: async (queryInterface, Sequelize) => { + if (queryInterface.sequelize.getDialect() === 'sqlite') { + await queryInterface.sequelize.query(` + CREATE TRIGGER project_insert_fts AFTER INSERT ON projects BEGIN + INSERT INTO projects_fts( + id, + warehouseProjectId, + currentRegistry, + registryOfOrigin, + originProjectId, + program, + projectName, + projectLink, + projectDeveloper, + sector, + projectType, + coveredByNDC, + NDCLinkage, + projectStatus, + projectStatusDate, + unitMetric, + methodology, + methodologyVersion, + validationApproach, + validationDate, + projectTag + ) VALUES ( + new.id, + new.warehouseProjectId, + new.currentRegistry, + new.registryOfOrigin, + new.originProjectId, + new.program, + new.projectName, + new.projectLink, + new.projectDeveloper, + new.sector, + new.projectType, + new.coveredByNDC, + new.NDCLinkage, + new.projectStatus, + new.projectStatusDate, + new.unitMetric, + new.methodology, + new.methodologyVersion, + new.validationApproach, + new.validationDate, + new.projectTag + ); + END;`); + + await queryInterface.sequelize.query(` + CREATE TRIGGER project_delete_fts AFTER DELETE ON projects BEGIN + DELETE FROM projects_fts WHERE id = old.id; + END; + `); + + await queryInterface.sequelize.query(` + CREATE TRIGGER project_update_fts AFTER UPDATE ON projects BEGIN + DELETE FROM projects_fts WHERE id = old.id; + INSERT INTO projects_fts( + id, + warehouseProjectId, + currentRegistry, + registryOfOrigin, + originProjectId, + program, + projectName, + projectLink, + projectDeveloper, + sector, + projectType, + coveredByNDC, + NDCLinkage, + projectStatus, + projectStatusDate, + unitMetric, + methodology, + methodologyVersion, + validationApproach, + validationDate, + projectTag + ) VALUES ( + new.id, + new.warehouseProjectId, + new.currentRegistry, + new.registryOfOrigin, + new.originProjectId, + new.program, + new.projectName, + new.projectLink, + new.projectDeveloper, + new.sector, + new.projectType, + new.coveredByNDC, + new.NDCLinkage, + new.projectStatus, + new.projectStatusDate, + new.unitMetric, + new.methodology, + new.methodologyVersion, + new.validationApproach, + new.validationDate, + new.projectTag + ); + END; + `); + }}, + + down: async (queryInterface, Sequelize) => { + if (queryInterface.sequelize.getDialect() === 'sqlite') { + await queryInterface.sequelize.query("DROP TRIGGER project_insert_fts;"); + await queryInterface.sequelize.query("DROP TRIGGER project_delete_fts;"); + await queryInterface.sequelize.query("DROP TRIGGER project_update_fts;"); + } + } +}; diff --git a/migrations/20211219184405-sqlite-triggers-units.cjs b/migrations/20211219184405-sqlite-triggers-units.cjs new file mode 100644 index 00000000..46102200 --- /dev/null +++ b/migrations/20211219184405-sqlite-triggers-units.cjs @@ -0,0 +1,105 @@ +'use strict'; + +module.exports = { + up: async (queryInterface, Sequelize) => { + if (queryInterface.sequelize.getDialect() === 'sqlite') { + await queryInterface.sequelize.query(` + CREATE TRIGGER unit_insert_fts AFTER INSERT ON units BEGIN + INSERT INTO units_fts( + id, + projectId, + buyer, + registry, + blockIdentifier, + identifier, + qualificationId, + unitType, + unitCount, + unitStatus, + unitStatusDate, + transactionType, + unitIssuanceLocation, + unitLink, + correspondingAdjustment, + unitTag, + vintageId + ) VALUES ( + new.id, + new.projectId, + new.buyer, + new.registry, + new.blockIdentifier, + new.identifier, + new.qualificationId, + new.unitType, + new.unitCount, + new.unitStatus, + new.unitStatusDate, + new.transactionType, + new.unitIssuanceLocation, + new.unitLink, + new.correspondingAdjustment, + new.unitTag, + new.vintageId + ); + END;`); + + await queryInterface.sequelize.query(` + CREATE TRIGGER unit_delete_fts AFTER DELETE ON units BEGIN + DELETE FROM unit_insert_fts WHERE id = old.id; + END; + `); + + await queryInterface.sequelize.query(` + CREATE TRIGGER unit_update_fts AFTER UPDATE ON units BEGIN + DELETE FROM units_fts WHERE id = old.id; + INSERT INTO units_fts( + id, + projectId, + buyer, + registry, + blockIdentifier, + identifier, + qualificationId, + unitType, + unitCount, + unitStatus, + unitStatusDate, + transactionType, + unitIssuanceLocation, + unitLink, + correspondingAdjustment, + unitTag, + vintageId + ) VALUES ( + new.id, + new.projectId, + new.buyer, + new.registry, + new.blockIdentifier, + new.identifier, + new.qualificationId, + new.unitType, + new.unitCount, + new.unitStatus, + new.unitStatusDate, + new.transactionType, + new.unitIssuanceLocation, + new.unitLink, + new.correspondingAdjustment, + new.unitTag, + new.vintageId + ); + END; + `); + } + }, + + down: async (queryInterface, Sequelize) => { + if (queryInterface.sequelize.getDialect() === 'sqlite') { + await queryInterface.sequelize.query("DROP TRIGGER unit_insert_fts;"); + await queryInterface.sequelize.query("DROP TRIGGER unit_delete_fts;"); + await queryInterface.sequelize.query("DROP TRIGGER unit_update_fts;"); + } + } +};