With the download of the generated Artifacts, a zip file was created in the default download location set for your Web Browser as:
Let's see what this zip file contains now.
Generated Artifacts content
The Generated Artifacts zip file contains the following:
- A LoadControl folder
- A SQL folder
- Two helpers for deployment and load
- The placeholder toolkit is in the replace_placeholders.ps1 file
- The placeholder configuration is in the replacement_config.json file
- A ParseError.log file (optional)
LoadControl folder
The LoadControl folder contains:
- One sql file by Layer configured in the Generator:
- Each layer file (010_Stage_Configuration.sql, 020_Raw Vault_Configuration.sql...) contains all the needed SQL code to create the structure of your Target System.
- Example of a part of an SQL file:
...
EXEC [LC].[AddOrUpdate_LoadConfig_LoadObject] @LoadConfig = N'My first Project - MS-DV', @ModelObject = N'', @ModelObjectPart = N'Stage Loader', @ModelObjectDataflow = N'', @ModelObjectLayer = N'Stage', @ModelObjectType = N'Stage', @LoadObject = N'STG_ST__Loader', @SchemaName = N'{myfirstproject-ms-dv#stage#schema_name}', @DatabaseName = N'{myfirstproject-ms-dv#stage#database_name}', @ServerName = N'{myfirstproject-ms-dv#stage#server_name}', @ErrorBehavior = N'Default', @ExecutionTechnology = N'SQL', @ExecutionSortOrder = 2, @ExecutionPriority = 0, @IsActive = 1;
EXEC [LC].[AddOrUpdate_LoadConfig_LoadObject] @LoadConfig = N'My first Project - MS-DV', @ModelObject = N'', @ModelObjectPart = N'Stage Loader', @ModelObjectDataflow = N'', @ModelObjectLayer = N'Stage', @ModelObjectType = N'Stage', @LoadObject = N'STG_ST__Loader', @SchemaName = N'{myfirstproject-ms-dv#stage#schema_name}', @DatabaseName = N'{myfirstproject-ms-dv#stage#database_name}', @ServerName = N'{myfirstproject-ms-dv#stage#server_name}', @ErrorBehavior = N'Default', @ExecutionTechnology = N'SQL', @ExecutionSortOrder = 2, @ExecutionPriority = 0, @IsActive = 1;
...
- The Load Control creation scripts and an Execution Load script for a native load with Microsoft SQL Server:
- The Load Control creation script (L000_Loadcontrol_Deployment.sql) contains all the needed SQL code to create the Load Control structure of your Target System
- The Execution Load script (LoadControl_Execution_My First Project.sql) allows the loading of data natively with Microsoft SQL Server
-
As you can observe, placeholders are used for the target database name and schema. Please Replace the placeholders in the Generated Artifacts before deploying the generated code in your target environment.
- See Load data with a native load control
- a Python file for a load with Airflow
- If you prefer to load data with Airflow instead of natively with Microsoft SQL Server
- See Load data with Apache Airflow
If the Property Configure LoadControl is set to False, only the Load Control creation script (L000_Loadcontrol_Deployment.sql) will be generated.
If the Property Deploy LoadControl is set to False, all the files will be generated except the Load Control creation script (L000_Loadcontrol_Deployment.sql).
SQL folder
The SQL folder contains one sql file by Layer configured in the Generator.
In this example, four layers are configured for the Generator:
- Stage layer
- Raw Vault layer
- Business Vault Layer
- Mart
Each file contains all the SQL code needed to create the tables, views, and stored procedures that make up the structure of your Target System.
Example of a part of a SQL file:
...
CREATE TABLE [{trainingdatavault#stage#schema_name}].[STG_ST_CreditCard] (
[BG_LoadTimestamp] DATETIMEOFFSET NULL
,[BG_SourceSystem] NVARCHAR(255) NULL
,[CreditCardID] INT NULL
,[CardType] NVARCHAR(50) NULL
,[CardNumber] NVARCHAR(25) NULL
,[ExpMonth] TINYINT NULL
,[ExpYear] SMALLINT NULL
,[ModifiedDate] DATETIME NULL
)
;
GO
...
As you can observe, a placeholder is used for the target database name and schema.
Before you deploy the generated code in your target environment, please Replace the placeholders in the Generated Artifacts.
Helpers for deployment and load
2 Powershell scripts allow the following:
- Deploy all the scripts in the target environment: deploy.ps1
- Execute the load of the data: execute.ps1
If the Property Configure LoadControl is set to False, the execute.ps1 artifact will not be generated.
ParseError.log file
If some errors occur during the generation of your Artifacts, the file ParseError.log will contain these errors.
Example of error:
ERROR LinkSourceView: Customer_Order_Link_link source view_1 ### TargetName: RDV_LNK_Customer_Order_Link_Source
Invalid amount of dataflows for ArchitectureModelObject name Customer_Order_Link_link source view_1
System.Exception: Invalid amount of dataflows for ArchitectureModelObject name Customer_Order_Link_link source view_1
at biGENIUS.Implementation.Base.DataflowBuilder.Build(ArchitectureModelObject architectureModelObject) in C:\.sources\bgaas\bigenius.implementation.base\src\biGENIUS.Implementation.Base\StatementBuilder\DataflowBuilder.cs:line 18
at biGENIUS.Implementation.Datavault.Mssql.SourceViewBuilder.Build(ArchitectureModelObject architectureModelObject) in C:\.sources\bgaas\bigenius.implementation.datavault.mssql\src\biGENIUS.Implementation.Datavault.Mssql\StatementBuilder\SourceViewBuilder.cs:line 22
at biGENIUS.Implementation.Datavault.Mssql.LinkSourceView.BuildScriptInternal() in C:\.sources\bgaas\bigenius.implementation.datavault.mssql\src\biGENIUS.Implementation.Datavault.Mssql\Template\LinkSourceView.cs:line 16
at biGENIUS.Implementation.Base.TemplateScriptBase.BuildScript(IGeneratorContext generatorContext, ArchitectureModelObject architectureModelObject, TemplateRenderingContext templateRenderingContext, StatementBuilderContext statementBuilderContext) in C:\.sources\bgaas\bigenius.implementation.base\src\biGENIUS.Implementation.Base\TemplateBase\TemplateScriptBase.cs:line 45
at biGENIUS.Implementation.Base.GeneratorHookBase.RenderTemplate(IGeneratorContext generatorContext, Assembly assembly, ArchitectureModelObject amo) in C:\.sources\bgaas\bigenius.implementation.base\src\biGENIUS.Implementation.Base\Hook\GeneratorHookBase.cs:line 169
In this case, no Dataflow was configured for the Link named Customer_Order_Link.
So, please now define the Dataflow and generate a new time.
If no errors occur during generation, the file ParseError.log will not exist in the Generated Artifact zip file.
Placeholder toolkit
It is composed when you deploy PowerShell script: replace_placeholders.ps1.
It uses a placeholder configuration file to replace the connection needed information in the generated artifacts.
For more information, please review Replace the placeholders in the Generated Artifacts.
Placeholder configuration
It is composed of a JSON file: replacement_config.json.
The placeholder toolkit uses it to replace the connection needed information in the generated artifacts.
For more information, please review Replace the placeholders in the Generated Artifacts.