From 61d5e44727168189ba422fc2f8850bc064fc6473 Mon Sep 17 00:00:00 2001 From: Serhii Filonenko Date: Fri, 27 Sep 2024 14:22:08 +0300 Subject: [PATCH] HCK-8196: adjust FE script for displying default ON NULL clause --- .../ddlProvider/ddlHelpers/columnDefinitionHelper.js | 8 +++++--- forward_engineering/ddlProvider/ddlProvider.js | 1 + 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/forward_engineering/ddlProvider/ddlHelpers/columnDefinitionHelper.js b/forward_engineering/ddlProvider/ddlHelpers/columnDefinitionHelper.js index 63b0b3e..ac1b7bc 100644 --- a/forward_engineering/ddlProvider/ddlHelpers/columnDefinitionHelper.js +++ b/forward_engineering/ddlProvider/ddlHelpers/columnDefinitionHelper.js @@ -55,7 +55,7 @@ module.exports = ({ _, wrap, assignTemplates, templates, commentIfDeactivated, w return type; }; - const getColumnDefault = ({ default: defaultValue, identity }) => { + const getColumnDefault = ({ default: defaultValue, defaultOnNull, identity }) => { if (!_.isEmpty(identity) && identity.generated) { const getGenerated = ({ generated, generatedOnNull }) => { if (generated === 'BY DEFAULT') { @@ -73,8 +73,10 @@ module.exports = ({ _, wrap, assignTemplates, templates, commentIfDeactivated, w }; return ` GENERATED${getGenerated(identity)} AS IDENTITY (${_.trim(getOptions(identity))})`; - } else if (defaultValue) { - return ` DEFAULT ${defaultValue}`; + } else if (defaultValue || defaultValue === 0) { + const onNull = defaultOnNull ? ' ON NULL' : ''; + + return ` DEFAULT${onNull} ${defaultValue}`; } return ''; }; diff --git a/forward_engineering/ddlProvider/ddlProvider.js b/forward_engineering/ddlProvider/ddlProvider.js index 2ecd844..55886e4 100644 --- a/forward_engineering/ddlProvider/ddlProvider.js +++ b/forward_engineering/ddlProvider/ddlProvider.js @@ -214,6 +214,7 @@ module.exports = (baseProvider, options, app) => { isUDTRef, dimension: jsonSchema.dimension, subtype: jsonSchema.subtype, + defaultOnNull: jsonSchema.defaultOnNull, ...(canHaveIdentity(jsonSchema.mode) && { identity: jsonSchema.identity }), }; },