Data Applications → Install and configure Oracle Cloud ERP v2
What's New
In the latest version of the data app made available in Q1 2024, the following changes have been made:
- This app now leverages Incorta Oracle Cloud ERP V2 BICC connector which has orchestration with jobs in Oracle Business Intelligence Cloud Connector.
- This app can now use View Objects (VOs)
Configuration Prerequisites
Before you configure the Oracle Cloud ERP data application, your Oracle Cloud ERP administrator will need to create a single user with the correct roles to access the Oracle Cloud ERP Business Intelligence Cloud Connector (BICC) and Universal Content Management (UCM). Select the following links for instructions:
- Create BICC user and assign roles
- Create UCM user and assign roles
- A BICC URL must be accessible by Incorta
- Other required roles
- ESS Administrator Role
- ORA_ASM_APPLICATION_IMPLEMENTATION_ADMIN_ABSTRACT
- OBIA_EXTRACTTRANSFORMLOAD_RWD
Note | Ensure only one user who can access BICC and Oracle Universal Content Manager (UCM). If OCI storage is used instead of UCM, then please refer to this link for information.
Installation and configuration steps
Here are the installation steps:
- Import the BICC Customization File
- Install the Data Application
- Setup the Fusion Connection
- Load Data into Incorta
- (Optional) Load Data into Google BigQuery
- Configure the Cloud ERP Application
- Adding new fields to existing tables
- Adding new VOs in Incorta Jobs
Refer to frequently asked questions and troubleshooting document if needed.
For any additional questions, please refer to our FAQs or contact our applications team.
Deployment use cases
When approaching the installation, it's important to understand the end consumption. The architected patterns of use for this data app are:
- Using data application in Incorta only. Data will be ingested into Incorta for analytics
- Using data application in Incorta to manage workloads for Google BigQuery. Data will be ingested into Incorta and flattened outputs will be provided to Google Bigquery for analytics. For this use case, be sure to complete the BigQuery destination step.
Cloud installation On-Premise istallation
Installation Overview
Cloud installation summary
- Import the BICC customization zip file in Oracle BIACM
- Install the Oracle Cloud ERP data app from the Incorta Marketplace
- Install the Fusion BICC connector from the Incorta Marketplace if required
- Configure the Fusion data connection
On-Premise installation summary
- Import the BICC customization zip file in Oracle BIACM
- Download and unzip the Oracle Cloud ERP archive; it has the tenant zip, BICC customization zip file and a data folder.
- Import the Incorta tenant and metadata files and do configuration
- Install the Oracle Cloud ERP BICC connector from the Incorta Marketplace
- Configure the Fusion data connection
Step 1: Import BICC customization zip file
Cloud and On-Premise must complete
- Log into Oracle BIACM. The URL will look like this one: https://sampledomain.fa.ocs.oraclecloud.com/biacm. Change the hostname to your own.
- On the right-hand side, under Manage Offerings, import the customization zip (E.g.
exportCustomization_2020-04-06_18_01_40.zip
) file.- Contact Incorta support to recieve the custom zip file.
- Click on the right-hand side icon to go to Manage Jobs, and here you will see the jobs that the customization file has seeded (e.g. Job_Fusion_AP).
- Refer to the Offerings Matrix table below to see which objects are needed to deploy a particular module. You may need to Reset the last extract date at the job level if the customer has already run extracts in the past
- Log into UCM. The URL will look like this one. Just change the hostname to your own: https://sampledomain.fa.ocs.oraclecloud.com/cs
- In the UCM screen, click on the ‘Search->Advanced’ tab in the left-hand bar, and in the Security Group, put OBIA% and hit search. Now you can input a string like invoiceheaderpvo in the field at the top right and search for the file.
Step 2: Install the data application
Cloud installation steps
If you have access to install or request the data application in Incorta Analytics:
- Sign in to Incorta Analytics.
- Select Marketplace in the navigation bar.
- Select Applications from the submenu bar.
- Search for and select Oracle Cloud ERP data app (BICC).
- Select Install.
On-premise installation steps
Installing on a new tenant
- Import the Incorta Tenant (this will be part of the data app install in the future)
- Log in to the Incorta CMC and make sure that the loader and analytic services have at least 6GB of on heap memory. If not, please edit the on heap settings and restart the services
- Click on Clusters>Cluster Name>Tenants, select + and then select the Import Tenant option and select the
TenantOracleCloudERP_<ver>.zip
file- Contact Incorta support to recieve the custom zip file.
- Follow the guided steps to create the tenant and login to the newly created tenant.
Installing on a pre-existing tenant
- Import schemas/business schemas/dashboard folders associated with the data app.
- Create a new Oracle Cloud applications data connection called
Fusion
and configure as per the screenshot below. - Ensure that Spark has adequate memory configured and that the following Spark Materialized View properties are configured in the CMC. Depending on the data, the application memory may have to be set higher.
- Use the Incorta interfact to navigate to Data > Local Data files
- Select New and upload the files from your local mydata folder in the extracted zip file, making sure to use the overwrite option.
Step 2: Configure the Oracle BICC and UCM
- Sign in to the Oracle BICC with the following URL and your host name:
https://<YOUR_HOST_NAME>.oracledemos.com/biacm/
. - In the toolbar, select Manage Offerings and Data Stores → Import Modifications.
- In the Import Modifications dialog box that pops up:
- Select Choose File.
- Select the
exportCustomization_<DATE>_<VERSION>.zip
file fromOracleFusion_<VERSION_NUMBER>.zip
. - Select Open.
- Select Import.
- Select the Offering drop down list to view the Incorta offerings, such as Incorta AP.
Step 3: Set up a Fusion connection
- Log in to Incorta and create or edit the Fusion data connection.
- Choose which storage type (UCM or Object Storage) you want get your data from:
- For UCM storage (refer to screenshot below):
- Oracle Cloud Applications URL : Put the oracle cloud erp URL, eg. https://fa-engu-test-saasfaprod1.fa.ocs.oraclecloud.com/
- Fill in the login and password
- Common fields:
- File name pattern :
file_<catalog>_<schema>_<table>-batch*.zip
- Root Query Text:
dSecurityGroup <matches> `OBIAImport`
- Leave other options with the default values or if you want to read only the files from a certain date (as those files may have extra fields than older ones), you can add a date filter at the data source of the field
Start Timestamp: >= '2024-01-01 12:00'
which will only load files created/modified since this date. - BICC Jobs : Here you have to configure the BICC Job names and the job IDs. If you have imported the tenant, then the only thing you need to verify are the job IDs for each of the jobs in BICC as those might have changed in the customer deployment.
- File name pattern :
- For UCM storage (refer to screenshot below):
The job names are what is set up in the schema tables, for example:
Step 4: Load Data into Incorta
From the scheduler tab either create a Load Plan, add the schemas by referring to the Matrix above, or use an existing load plan.
For the initial full load, login to the Oracle BICC, navigate to the 4th icon on the right and click on Manage Jobs.
Then for every schema in the load plan above click on the gear icon on the right and click on Reset to full extract.
In Incorta execute the load plan and go to the Schema → Load Jobs to monitor the execution. Incorta will automatically invoke the BICC JOB API, run the BICC extract and then stream the data file from UCM into Incorta and load the data.
Subsequent load plan executions after the full load will run in incremental mode .
Follow the BICC steps above if you again want to reset to full extract. If you want to check the Job execution status in BICC then click on Manage Job Schedules
Step 5 (optional): Send data to Google BigQuery
You will need to complete a couple of steps to prepare it to push your EBS data to BigQuery.
At a high level, you will follow these steps to get Incorta talking to BigQuery:
- Configure Incorta to write to Google BigQuery via a Data Destination
- Load the schemas to push the source data first to Incorta and then to BigQuery
- In the Incorta UI navigate to Data->Data Destinations and find the GoogleBigQuery data destination. Refer to the Connecting and Pushing Data to BigQuery article available on Incorta Community for instructions on how to configure it to connect to your BigQuery instance.
Now we need to open the required schemas and set up the GoogleBigQuery data destination to the schemas and set the target schema for example to ORACLE_ERP_CDC. When the schemas are loaded, Incorta will create the dataset in BigQuery and all the tables will land there. Please verify that these settings have been configured for all the schemas that are sent to BigQuery.
Offerings Matrix
Module | Incorta Schemas needed | Incorta Jobs needed |
---|---|---|
Advanced Payables (AP) | Fusion_CAL_COMMON Fusion_Item_Common Fusion_HR_Common Fusion_FND_Common Fusion_FIN_Common Fusion_PARTY_COMMON Fusion_AP Fusion_PO | Job_Fusion_CAL_COMMON Job_Fusion_Item_Common Job_Fusion_HR_Common Job_Fusion_FND_Common Job_Fusion_FIN_Common Job_Fusion_PARTY_COMMON Job_Fusion_AP Job_Fusion_PO |
Accounts Receivables (AR) | Fusion_CAL_COMMON Fusion_Item_Common Fusion_HR_Common Fusion_FND_Common Fusion_FIN_Common Fusion_PARTY_COMMON Fusion_AR Fusion_AR_SNP Fusion_AR_MV | Job_Fusion_CAL_COMMON Job_Fusion_Item_Common Job_Fusion_HR_Common Job_Fusion_FND_Common Job_Fusion_FIN_Common Job_Fusion_PARTY_COMMON Job_Fusion_AR Job_Fusion_AR_SNP Job_Fusion_AR_MV |
Fixed Assets (FA) | Fusion_CAL_COMMON Fusion_Item_Common Fusion_HR_Common Fusion_FND_Common Fusion_FIN_Common Fusion_PARTY_COMMON Fusion_FA | Job_Fusion_CAL_COMMON Job_Fusion_Item_Common Job_Fusion_HR_Common Job_Fusion_FND_Common Job_Fusion_FIN_Common Job_Fusion_PARTY_COMMON Job_Fusion_FA |
General Ledger and Sub ledgers (GL & XLA) | Fusion_CAL_COMMON Fusion_Item_Common Fusion_HR_Common Fusion_FND_Common Fusion_FIN_Common Fusion_PARTY_COMMON Fusion_GL Fusion_XLA Fusion_XLA_MV | Job_Fusion_CAL_COMMON Job_Fusion_Item_Common Job_Fusion_HR_Common Job_Fusion_FND_Common Job_Fusion_FIN_Common Job_Fusion_PARTY_COMMON Job_Fusion_GL Job_Fusion_XLA |
Inventory (INV) | Fusion_CAL_COMMON Fusion_Item_Common Fusion_HR_Common Fusion_FND_Common Fusion_FIN_Common Fusion_PARTY_COMMON Fusion_INV | Job_Fusion_CAL_COMMON Job_Fusion_Item_Common Job_Fusion_HR_Common Job_Fusion_FND_Common Job_Fusion_FIN_Common Job_Fusion_PARTY_COMMON Job_Fusion_INV |
Order Management(ONT) | Fusion_CAL_COMMON Fusion_Item_Common Fusion_HR_Common Fusion_FND_Common Fusion_FIN_Common Fusion_PARTY_COMMON Fusion_ONT | Job_Fusion_CAL_COMMON Job_Fusion_Item_Common Job_Fusion_HR_Common Job_Fusion_FND_Common Job_Fusion_FIN_Common Job_Fusion_PARTY_COMMON Job_Fusion_ONT |
Procurement (PO) | Fusion_CAL_COMMON Fusion_Item_Common Fusion_HR_Common Fusion_FND_Common Fusion_FIN_Common Fusion_PARTY_COMMON Fusion_PO | Job_Fusion_CAL_COMMON Job_Fusion_Item_Common Job_Fusion_HR_Common Job_Fusion_FND_Common Job_Fusion_FIN_Common Job_Fusion_PARTY_COMMON Job_Fusion_PO |
Projects (PRJ) | Fusion_CAL_COMMON Fusion_Item_Common Fusion_HR_Common Fusion_FND_Common Fusion_FIN_Common Fusion_PARTY_COMMON Fusion_PRJ Fusion_GMS | Job_Fusion_CAL_COMMON Job_Fusion_Item_Common Job_Fusion_HR_Common Job_Fusion_FND_Common Job_Fusion_FIN_Common Job_Fusion_PARTY_COMMON Job_Fusion_PRJ Job_Fusion_GMS |
GL Budgetary Control | Fusion_CAL_COMMON Fusion_Item_Common Fusion_HR_Common Fusion_FND_Common Fusion_FIN_Common Fusion_PARTY_COMMON | Job_Fusion_CAL_COMMON Job_Fusion_Item_Common Job_Fusion_HR_Common Job_Fusion_FND_Common Job_Fusion_FIN_Common Job_Fusion_PARTY_COMMON Job_Fusion_Budgetary_Control |
HCM | Fusion_CAL_COMMON Fusion_HCM Fusion_HCM_MV Fusion_HCM_REC Fusion_HCM_Payroll | Job_Fusion_CAL_COMMON Job_Fusion_HR_Common Job_Fusion_HCM Job_Fusion_HCM_REC Job_Fusion_HCM_Payroll |
Procurement(Sourcing) | Fusion_CAL_COMMON Fusion_Item_Common Fusion_HR_Common Fusion_PARTY_COMMON | Job_Fusion_CAL_COMMON Job_Fusion_Item_Common Job_Fusion_HR_Common Job_Fusion_FIN_Common Job_Fusion_PARTY_COMMON Job_Fusion_Sourcing |
PLM | Fusion_CAL_COMMON Fusion_Item_Common Fusion_HR_Common Fusion_FND_Common Fusion_PARTY_COMMON Fusion_PLM | Job_Fusion_CAL_COMMON Job_Fusion_Item_Common Job_Fusion_HR_Common Job_Fusion_FND_Common Job_Fusion_PARTY_COMMON Job_Fusion_PLM |
MFG | Fusion_CAL_COMMON Fusion_Item_Common Fusion_HR_Common Fusion_FND_Common Fusion_FIN_Common Fusion_PARTY_COMMON Fusion_MF Fusion_INV Fusion_ONT | Job_Fusion_CAL_COMMON Job_Fusion_Item_Common Job_Fusion_HR_Common Job_Fusion_FND_Common Job_Fusion_FIN_Common Job_Fusion_PARTY_COMMON Job_Fusion_MF Job_Fusion_INV Job_Fusion_ONT |
COGS | Fusion_CAL_COMMON Fusion_Item_Common Fusion_HR_Common Fusion_FND_Common Fusion_FIN_Common Fusion_PARTY_COMMON Fusion_COGS | Job_Fusion_CAL_COMMON Job_Fusion_Item_Common Job_Fusion_HR_Common Job_Fusion_FND_Common Job_Fusion_FIN_Common Job_Fusion_PARTY_COMMON Job_Fusion_COGS |
Cash Management | Fusion_CAL_COMMON Fusion_Item_Common Fusion_HR_Common Fusion_FND_Common Fusion_FIN_Common Fusion_PARTY_COMMON Fusion_CashManagement | Job_Fusion_CAL_COMMON Job_Fusion_Item_Common Job_Fusion_HR_Common Job_Fusion_FND_Common Job_Fusion_FIN_Common Job_Fusion_PARTY_COMMON Job_Fusion_CashManagement |
CX_Subscription | Fusion_CAL_COMMON Fusion_Item_Common Fusion_HR_Common Fusion_FND_Common Fusion_FIN_Common Fusion_PARTY_COMMON Fusion_CX_Subscription Fusion_ONT | Job_Fusion_CAL_COMMON Job_Fusion_Item_Common Job_Fusion_HR_Common Job_Fusion_FND_Common Job_Fusion_FIN_Common Job_Fusion_PARTY_COMMON Job_Fusion_CX_Subscription Job_Fusion_ONT |
Step 6: Configure the Cloud ERP Application
Incorta data application has pre-built metadata that can be used to load data from Oracle Cloud ERP and view it in pre-built dashboards. This is a modular accelerator data application for Financials/Supply Chain/HCM analytics that can be used for rapid deployment and can be easily customized.
Configure Seeded Session Variables
Configure the default values of these Incorta session variables which are used in dashboards.
Default_Ledger: You can get all ledger names from the Fusion_FIN_Common.Ledger table and then ask the customer for the default
Default_Period: You can get all period names from the Fusion_FIN_Common.GLFiscalPeriod table and then ask the customer for the default
Default_Start_Year: Update the year value as required
Other Optional Configurations
Configure GL Account KFF
Determine which Chart of Accounts should be used for reporting
Most customers will already know which chart of accounts they want to use for their reporting. Customers can query the Fusion_FIN_Common.Ledger table by creating an insight in Incorta to determine which chart_of_account_id to use.
Get the list of segments used by customer from Fusion UI
In most cases customers will know which segments they want to use for reporting. Customers can look up the information from the Fusion UI as follows:
- Login as a user who can access the “Setup and Configuration” option
- Go to Setup and Maintenance for Financials and go to FInancial Reporting Structures
- Go to Manage Chart of Account Structures
- Type “GL” in as the Key flexfield code and press search
- Click on “Manage Structures” and press search. This will bring up a list of accounting structures
- Edit the structure the customer wants to use for reporting by clicking the pencil icon
- This will show the mapping of account segments. Use this information to update the Incorta objects to reflect the customer’s implementation of the account key flexfield
Update the Business Views to reflect the customer’s implementation
Once the segments needed for reporting are identified, update the business view to reflect the customer’s configuration.
In the FusionGeneralLedger Business Schema make sure that the correct segment columns from the code combinations table are mapped to the Entity, Cost Center and Account segments fields in the business schema. For example, out of the box, Incorta has mapped segment2 to cost center but in a customer’s instance, it could be segment3 etc.
If additional business views are needed for additional qualifying segments (only 3 are supported in the OOTB blueprints), add new business views. For example, create a new business view called product and put all the columns in that view for that segment. If the segment has no hierarchy, then just add the <segment name>_c
and DESC_<segment_name>
columns into the business view.
If the segment has a hierarchy, the hierarchy is already flattened in the VO. Add all the columns for each level in the hierarchy to the business view. Example: Product view - add 2 columns per level like product 1-5.
Update the join between the Fusion_XLA.XLAAccounts table and the Fusion_FIN_COMMON.CodeCombination table
This Incorta table holds the accounts per module like AP, AR etc… (used in the GL reconciliation dashboards).
- Edit the table and select the correct segment field for the account. The default value that comes out of the box is segment3 . Save and load the table.
- The correct segment, based on the customer’s configuration, from the Fusion_FIN_Common.CodeCombination table must be joined to the account segment. For example, if segment2 is the accounting segment, then update the join below to segment2.
Update the chart of accounts in the MV GLAccountHierFlat in the Fusion_FIN_Common schema
Update the chart of accounts and tree code in the MV named GLAccountHierFlat in the Fusion_FIN_Common schema as shown below to reflect the customer's chart of accounts and tree code. Also check and update the segment columns used. Here are the questions you can ask customer to determine the parameters used in the Incorta GLAccountHierFlat MV:
- What is the name of the account tree that you want to use?
- What is the name of the account tree version that you want to use?
- What is the fnd value set category name for the GL account hierarchy nodes?
You will use the answers to the above questions to update the MV with the values specific to the customer’s implementation.
- If a customer has other GL segment hierarchies they want to bring into Incorta, e.g cost center hierarchy, they must create similar MVs and use the same SQL, but replace the parameters with values specific to those hierarchies.
- They will also create joins to the CodeCombination PVO to this new MV similar to the GL account segment hierarchy.
- They will also need to create one alias per hierarchy if they have multiple hierarchies for the same segment (using the hierarchy name as a filter in the join).
- Note that the hierarchy name cannot be dynamically selected from the dashboard as Incorta joins are computed at load time.
Example: Edit the SQL in the MV and replace the right tree version name, the right code combination segment to join on (in our example we use segment 3 for account) and the right valuecategory for the segment. These are highlighted in the SQL below.
SELECTgsh.dep31pk1value || ' - ' || lvl1.DESCRIPTION AS account_level1,gsh.dep30pk1value || ' - ' || lvl2.DESCRIPTION AS account_level2,gsh.dep29pk1value || ' - ' || lvl3.DESCRIPTION AS account_level3,gsh.dep28pk1value || ' - ' || lvl4.DESCRIPTION AS account_level4,gsh.dep27pk1value || ' - ' || lvl5.DESCRIPTION AS account_level5,gsh.dep26pk1value || ' - ' || lvl6.DESCRIPTION AS account_level6,gsh.dep25pk1value || ' - ' || lvl7.DESCRIPTION AS account_level7,gsh.dep24pk1value || ' - ' || lvl8.DESCRIPTION AS account_level8,gsh.dep0pk1value || ' - ' || lvl9.DESCRIPTION AS account_level9,gcc.CODECOMBINATIONSEGMENT1,gcc.CODECOMBINATIONSEGMENT2,gcc.CODECOMBINATIONSEGMENT3,gcc.CODECOMBINATIONSEGMENT4,gcc.CODECOMBINATIONSEGMENT5,gcc.CODECOMBINATIONSEGMENT6,gcc.codecombinationid,lvl2.FLEXVALUE lvl2_flexvalue,lvl3.FLEXVALUE lvl3_flexvalue,lvl4.FLEXVALUE lvl4_flexvalueFROMFusion_FIN_COMMON.flex_tree_vs_gl_account_vi gsh,(SELECTgcf.treestructurecode,gcf.treecode,gcf.treeversionid,gcf.dep0pk1value,MAX(gcf.distance) AS maxdistanceFROMFusion_FIN_COMMON.flex_tree_vs_gl_account_vi gcf,Fusion_FIN_COMMON.fndtreeversiontlp1 tvtWHEREgcf.treestructurecode = tvt.treestructurecodeAND gcf.treecode = tvt.treecodeAND gcf.treeversionid = tvt.treeversionidAND tvt.treeversionname = 'Account_Tree_Current1'GROUP BYgcf.treestructurecode,gcf.treecode,gcf.treeversionid,gcf.dep0pk1value) hier,Fusion_FIN_COMMON.fndflexvaluespvo lvl1,Fusion_FIN_COMMON.fndflexvaluespvo lvl2,Fusion_FIN_COMMON.fndflexvaluespvo lvl3,Fusion_FIN_COMMON.fndflexvaluespvo lvl4,Fusion_FIN_COMMON.fndflexvaluespvo lvl5,Fusion_FIN_COMMON.fndflexvaluespvo lvl6,Fusion_FIN_COMMON.fndflexvaluespvo lvl7,Fusion_FIN_COMMON.fndflexvaluespvo lvl8,Fusion_FIN_COMMON.fndflexvaluespvo lvl9,Fusion_FIN_COMMON.CodeCombination gccWHEREgsh.dep0pk1value = hier.dep0pk1valueAND gsh.distance = hier.maxdistanceAND gsh.treestructurecode = hier.treestructurecodeAND gsh.treecode = hier.treecodeAND gsh.treeversionid = hier.treeversionidAND gsh.dep31pk1value = lvl1.FLEXVALUEAND gsh.dep30pk1value = lvl2.FLEXVALUEAND gsh.dep29pk1value = lvl3.FLEXVALUEAND gsh.dep28pk1value = lvl4.FLEXVALUEAND gsh.dep27pk1value = lvl5.FLEXVALUEAND gsh.dep26pk1value = lvl6.FLEXVALUEAND gsh.dep25pk1value = lvl7.FLEXVALUEAND gsh.dep24pk1value = lvl8.FLEXVALUEAND gsh.dep0pk1value = lvl9.FLEXVALUEAND gsh.dep0pk1value = gcc.CODECOMBINATIONSEGMENT3AND lvl1.valuecategory = 'Account'AND lvl2.valuecategory = 'Account'AND lvl3.valuecategory = 'Account'AND lvl4.valuecategory = 'Account'AND lvl5.valuecategory = 'Account'AND lvl6.valuecategory = 'Account'AND lvl7.valuecategory = 'Account'AND lvl8.valuecategory = 'Account'AND lvl9.valuecategory = 'Account'
Load the MV GLAccountHierFlat in the Fusion_FIN_Common schema
Load the MV GLAccountHierFLat in the Fusion_FIN_Common Schema. This will refresh the data to reflect the customer’s configuration.
Update Reconciliation Incorta Analyzer table to reflect correct account segment column
The OOTB data app uses Segment2 for Account. If a customer uses a different segment column, the Incorta Analyzer table named XLA_Accounts in schema needs to be updated to reflect this.
Configure Descriptive Flexfields (DFFs)
A flexfield is a set of placeholder fields that are associated with a business object. Oracle Cloud ERP Applications provides three types of flexfields — descriptive, extensible, and key. This section describes how to support a descriptive flexfield (DFF) like Attribute1 etc for a particular table in Incorta -
In the Oracle Cloud ERP there will be a separate VO object for a table’s flexfields. For example in the ContractHeaderP VO the flex VO is called: FscmTopModelAM.ContractsCoreAM.HdrDFBIAM.FLEX_BI_ContractHeaderFlexfield_V. Find out the name of the flexfield VO first.
Look at the section ‘Adding new Fusion ERP table in Incorta’ on how to import this VO into Incorta, please note the key fields; they will be like S_K_5000 etc…
Join this VO as a parent table to the base VO. Use the key columns of the Base VO to join the S_K_5000 columns in the flex VO.
Add the
DESC_ field
from the flex VO into a business schema and add the appropriate label . For eg in the contractHeader the end user dff column name may be called ProjectMarket and the flexfield value field in the VO would be called as DESCPROJECTMARKET . So we can add the label as ‘Project Market’Load the VO
- Note: We have included some DFF VOs in the Fusion_FLX_Common schema, since flex VOs are deployment specific you would need to extract the existing flex VO in BICC, then download the mdcsv file from BICC, upload to Incorta (as per the instructions in ‘Adding new Fusion ERP table in Incorta section) , and save the flex VO in Incorta to get the updated fields.
If no fields are selected in the flex VO please edit the VO in BICC , do a select all and save the VO.
If you don’t see some flex VOs in BICC then the customer needs to deploy the DFFs from the Fusion application.
For FlexFields to be available in BI, you need to do the following in the Fusion app:
- For FlexFields to be available in BI, you need to do the following in the Fusion app:
- Go to Manage Descriptive FlexFields task
- Query the DFF CODE
- Go to edit and find needed attributes
- Edit the attribute, you will find a "BI Enabled" check box
- Customer need to enable this check box, save it
- Deploy that flex code
- Run "Import Oracle Fusion Data Extensions for Transactional Business Intelligence" Ess job
- Once the above is processed, the flexfields should be available for extract in BICC
- Refer to steps 1-3 of this Oracle blog
- For additional information on finding a desriptive flecfield DFF name, go here.
- For FlexFields to be available in BI, you need to do the following in the Fusion app:
Seeded flexfield VOs in Fusion_FLX_COMMON schema
DESCRIPTIVE_FLEXFIELD_NAME | Flex VO Name | Base VO (will be child) | APPLICATION_TABLE_NAME |
---|---|---|---|
FscmTopModelAM.CustAcctInformationBIAM.FLEX_BI_CustAcctInformation_VI | CustAcctInformationVO | HZ_CUST_ACCOUNTS | |
CE_EXTERNAL_TRANSACTIONS | FscmTopModelAM.ExternalTransactionBIAM.FLEX_BI_ExternalTransaction_VI | FscmTopModelAM.FinCeCashTransactionsAM.ExternalTransactionsPVO | CE_EXTERNAL_TRANSACTIONS |
ContractHeaderFlexfield | FscmTopModelAM.ContractsCoreAM.HdrDFBIAM.FLEX_BI_ContractHeaderFlexfield_VI | FscmTopModelAM.ContractsCoreAM.ContractHeaderP | OKC_K_HEADERS_ALL_B |
ContractLineFlexfield | fscmtopmodelam.contractscoream.lndfbiam_flex_bi_contractlinedescflexfield_vi | FscmTopModelAM.ContractsCoreAM.ContractHeaderLinesP | OKC_K_LINES_ALL_B |
EGP_SYSTEM_ITEMS_DFF | FscmTopModelAM.EgpItemsPublicModelAM.ItemBaseDFFBIAM.FLEX_BI_ItemBaseDFF_VI | FscmTopModelAM.EgpItemsPublicModelAM.Item | EGP_SYSTEM_ITEMS_B |
EGO_ITEM_EFF_B | FscmTopModelAM.EgpItemsPublicModelAM.ItemEFFBIFlattenedVO | EGP_SYSTEM_ITEMS_B | |
INV_MATERIAL_TXNS | FscmTopModelAM.InxTxnDFFBIAM.FLEX_BI_InxTxnDFF_VI | FscmTopModelAM.InventoryAM.InventoryTransactionDetailPVO | INV_MATERIAL_TXNS |
PJC_EXP_ITEMS_DESC_FLEX | FscmTopModelAM.PjcEiBIAM.FLEX_BI_PjcEi_VI | FscmTopModelAM.PjctransactionstAM.expenditureitempvo | PJC_EXP_ITEMS_ALL |
PJC_TXN_XFACE_DESC_FLEX | FscmTopModelAM..PjcUnProcDFFBIAM.FLEX_BI_Pjc_UnprocDFF_VI | FscmTopModelAM.PjcTransactionsAM.ProjectUnprocessedCostTransactionPVO | PJC_TXN_XFACE_ALL |
PJF_PROJECTS_DESC_FLEX | FscmTopModelAM.PJF_PROJECTS_ALLBIAM.FLEX_BI_PJF_PROJECTS_ALL_VI | FscmTopModelAM.PjfProjectAM.Project | PJF_PROJECTS_ALL_B |
PJF_TASK_STRUCTURE_DFF | FscmTopModelAM.TaskDffBIAM.FLEX_BI_TaskDff_VI | FscmTopModelAM.PjfProjectDefinitionAM.TaskVLPVO | PJF_PROJ_ELEMENTS_B |
POR_REQUISITION_HEADERS | FscmTopModelAM.RequisitionHeaderPublicBIAM.FLEX_BI_RequisitionHeaderPublic_VI | FscmTopModelAM.PrcPorPublicViewAM.RequisitionHeaderP1 | POR_REQUISITION_HEADERS_ALL |
POR_REQUISITION_LINES | FscmTopModelAM.RequisitionLinePublicBIAM.FLEX_BI_RequisitionLinePublic_VI | FscmTopModelAM.PrcPorPublicViewAM.RequisitionLineP1 | POR_REQUISITION_LINES_ALL |
POZ_SUPPLIER_SITES_ALL_M | FscmTopModelAM.PozSupplierSitesDFFPublicBIAM.FLEX_BI_PozSupplierSitesDFFPublic_VI | FscmTopModelAM.PrcPozPublicViewAM.SupplierSitePVO | POZ_SUPPLIER_SITES_ALL |
PO_HEADERS | FscmTopModelAM.POHeaderDFFPublicBIAM.FLEX_BI_POHeaderDFFPublic_VI | FscmTopModelAM.PrcPoPublicViewAM.StandardHeaderPVO | PO_HEADERS_ALL |
PO_LINES | FscmTopModelAM.POLineDFFPublicBIAM.FLEX_BI_POLineDFFPublic_VI | FscmTopModelAM.PrcPoPublicViewAM.StandardLinePVO | PO_LINES_ALL |
RA_CUSTOMER_TRX | FscmTopModelAM.TransactionHeaderFLEXBIAM.FLEX_BI_TransactionHeaderFLEX_VI | FscmTopModelAM.FinArTopPublicModelAM.TransactionHeaderPVO | RA_CUSTOMER_TRX_ALL |
RCV_TRANSACTIONS | FscmTopModelAM.RcvTxnDFBIAM.FLEX_BI_RcvTxnDF_VI | FscmTopModelAM.RcvReceiptsAM.ReceivingReceiptTransactionPVO | RCV_TRANSACTIONS |
FscmTopModelAM.AssetCategoryDffBIAM.FLEX_BI_AssetCategoryDff_VI | FscmTopModelAM.FinFaTrackDescDetailsAM.AdditionBasePVO | FA_ADDITIONS_B | |
FscmTopModelAM.DeliveryDFFBIAM.Flex_BI_DeliverDFF-VI | WSH_NEW_DELIVERIES | ||
DOO_HEADERS_EFF_B | FscmTopModelAM.DooTopAM.HeaderBIEffEFFBIFlattened | FscmTopModelAM.ScmExtractAM.DooBiccExtractAM.HeaderExtractPVO | |
DOO_LINES_EFF_B | FscmTopModelAM.DooTopAM.FulfillLineBIEffEFFBIFlattened | FscmTopModelAM.ScmExtractAM.DooBiccExtractAM.LineExtractPVO |
Supporting Drill to Cloud ERP Page
Incorta can support drill to the Cloud ERP provided a URL exists in which we can pass the ID, here are some sample URLS which can be configured in the URL field of a insight, we just need to modify the host name.
Purchase Requisitions
Purchase Requisitions: https://<host>/fscmUI/faces/FndOverview?fnd=%2FWEB-INF%2Foracle%2Fapps%2Fprc%2Fpor%2FmanageReq%2Fui%2Fflow%2FManageReqMainAreaFlow.xml%23ManageReqMainAreaFlow;paramInvokedApp%3DNOTIFICATION%3BparamReqHeaderId%{EBS_PO.PO_REQUISITION_HEADERS_ALL.REQUISITION_HEADER_ID};;;false;256;;;&fndGlobalItemNodeId=itemNode_my_information_purchase_requisition
AP Invoices
https://fa-engu-test-saasfaprod1.fa.ocs.oraclecloud.com/fscmUI/faces/deeplink?objType=AP_VIEWINVOICE&action=VIEW&objKey=InvoiceId={FusionPayablesTransactions.InvoiceHeaders.INVOICE_ID}
Please refer to the following Oracle documentation for further support.
- https://docs.oracle.com/en/cloud/saas/procurement/23a/fapaa/deep-links-for-procurement.html#s20076270
- https://cloudcustomerconnect.oracle.com/posts/cbb022f02b
Sizing
To figure out data sizing for Oracle cloud ERP please ask the customer to create a BI Publisher report using the below sql and send the Incorta Applications team (applications@incorta.com) the output:
select owner,table_name, num_rows , round(blocks*8/1024) size_mb from all_tables where owner not in ('SYS','SYSTEM') order by 1,2
Step 7: Adding new fields to existing Tables in Incorta
- To integrate new fields into already existing tables in Incorta, go to BICC and under Manage Jobs on the right open the Job which has the VO object you are trying to update.
- Click on the Datastore and then click on Select Columns on the top right
Then select the columns which you want to, hit Save and Done
- In Incorta go into the schema where the table is and click on the Datasets, select Validate and then verify that the column has been added
- Select Done and Save the changes and do a full load onto the table
- Verify the values in the new field using Explore Data
Step 8: Adding new VOs in Incorta Jobs
Users will have situations where they want to bring in additional data from Cloud ERP systems. The main method to bring in Cloud ERP data into Incorta is through VO (View Objects).
We will discuss the high level steps below:
- Identify the VO that has the data that is needed for reporting in Incorta
- Refer to the Extract VOs
Create the table corresponding to the new VO being added in Incorta
- Add the VO to an offering
- Then add the VO to an existing job or a new job in BICC
- Log into Incorta If required, add the job name and job ID in the Fusion data connection
- Use the schema wizard to Import the VO definitions to create an Incorta table, set up the job name, and select Incorta as the value for the ‘Start BICC jobs Using’ option, as shown below.
- Create the Joins from child to parent. Create any formula columns if needed.
- Load the physical schema in Incorta
- Create or update a business schema
- Create new dashboards on top of that business schema and validate the data and joins.
Find the VO in BICC. If VO is not found, add a new VO to BICC
Note that all VOs are not pre-seeded.
- Log into Oracle BICC, search for those VOs. We can also add the VOs to a custom offering and we can just extract that offering
- If the VO is not present you can add the VO, see steps and screenshots below If the VO is not found, you can add it by going to manage offering and Data Store on the right hand top corner as shown below.
Select the offering and click the + button to add the new VO to the offering. Add the VO to be added:
Select Save.
Select columns to be extracted in the VO you just added:
Select the desired columns. Select save.
Data Security
To implement data security by org for Fusion, please review the below suggestion.
- Please check these two OTBI subject areas below ,these subject have all the user and role info, more info in this Oracle document link
- Security - Audit Real time"
- Security - Roles and Privileges Real Time
- Some VOs for these are:
- HcmTopModelAnalyticsGlobalAM.AseAnalyticsAM.FndDataSecurityPVO
- HcmTopModelAnalyticsGlobalAM.AseAnalyticsAM.OpssRolePVO
- Define a excel file which has user and the list of BU they have access to
- For example, the userid is the incorta user id
- userId, org_id
- U1, org1
- U1, org2
- U2 , org1
- For example, the userid is the incorta user id
- Upload the file in incorta and create a table in incorta using it and load it
- Create a internal session variable called GetOrgId from the Schema tab with the following expression
query(<schema>.security_tbl.org_id,<schema>.security_tbl.userId=$user)
- Add a security filter to the base transaction table you want to secure based on the following variable, this condition returns all records if the user is an administrator.
or($user='demo’ ,inlist(<Fusion_schema.transaction_table>.org_id,$GetOrgId))
- Keep in mind that the base table in the query plan is the driving table for the security so the filter has to go there. Refer to this article on how to secure the data.
Oracle OCI Object Storage
You can access BICC content in Object Storage.
- Login to your Oracle cloud account
- Navigate to Object Storage tab
- View all the existing buckets associated with your region.
- Click on Profile on the top right hand side → select your profile
- Click API Keys on the bottom left hand side
- Add new API Key > Download the Private & Public key files
- Click Add > copy Configuration file details
Create the configuration file
* Make sure you have the private & public downloaded key in the same folder to be saved into incorta domain (eg. /IncortaAnalytics)* Start terminal session on the same directory folder of the keys* Type Code ```<cong_file_Name>```. It will open a text file* Paste the configuration file preview code and add the path of the private key fileNow configure the Fusion data connection with the details of Object storage
Object Storage:
- For the Object Storage:
- OCI configuration file path: the path to the configuration file for Oracle Object storage, containing information about the user, profile, tenancy ID and region.
- OCI configuration profile: the profile you wish to access your data from. The configuration file provided can contain multiple profiles, each of which has its own authentication credentials, so the user should specify which profile to work with.
- Bucket: the name of the bucket which contains the target data files. (a bucket is a logical container for storing objects. It can be perceived as folder in file system)
- For the Object Storage:
FAQs
What should I do if my BICC fails to load? Add a filter in the VO or consider using the chunking option.
How can I always do full load for a VO?
- In BICC edit the VO and uncheck the option below then the VO extract. Now it will always be a full load.
- Disable the incremental option in the Incorta table’s dataset tab and choose the ‘Load last batch’ option.
How do I handle source deletion of rows?
- Create a new Job in BICC for the particular VO
- Create a new Connection and set the file type to PECSV and add the Job name and ID pair
- Create a new Incorta schema for the PK table and add the PK table using the Schema wizard
- Always do a full load of the above PK table. Make sure that the Incremental toggle is turned off for this table
- Make the above table a parent of the base table by creating a child join from the base table to this PK table.
- Apply a table security filter on the base table as - "a field of parent table is not null" .
- Sample security filter on base table using the parent table field -
not(isNull(Test.parent_table_with_keys.id))
- Sample security filter on base table using the parent table field -
- Refer to this article for additional information.
- For Google BigQuery, create a routine in BigQuery to delete these rows from the CDC table, you have to open a query window and run the create statement
CREATE OR REPLACE PROCEDURE incorta-se.Raw_Fusion_Example_Delete.APInvoiceHeaderDelete()BEGINDELETE FROM Raw_Fusion_Example_Delete.APInvoiceHeaderWHERE InvoiceID IN (SELECT APIH.INVOICEIDFROM Raw_Fusion_Example_Delete.APInvoiceHeader APIHLEFT OUTER JOIN Raw_Fusion_Example_Delete.pk_invoiceheaderpvoAPIHDON APIH.INVOICEID = APIHD.INVOICEIDWHERE APIHD.INVOICEID IS NULL);END;
For On-Prem, what is the error: Error: java.io.IOException: Cannot run program "chmod": error=24, Too many open files
?
This issue happens because the connector build now has multiple jars, so at the time of start up, the server will try to load all the available connectors, which requires opening all the connector jars; this hits the OS limit of the allowed number of open files per process.
On the server run this command: ulimit -a output
Check the open files parameter, if it is 1024 then fix it by increasing the number of open files. Edit this file /etc/security/limits.conf and add the following lines:
- soft nproc 65535
- hard nproc 65535
- soft nofile 65535
- hard nofile 65535
Restart both the services.
How do I ingest an Oracle BIP report output into Incorta?
Use the Fusion V1 connector. Refer to this article for more information.
How do I delete a zip file in UCM?
Login to UCM, search for the file and click on the ‘i’ icon. Click on the Delete button.
Does Incorta support Incremental extracts for Oracle Cloud ERP? Yes
How do you keep the VOs updated based on the Oracle releases?
Oracle can add new columns to the VOs, so if needed, just open and save the table in Incorta.
How should I size the Incorta server?
There is a DB script for an Oracle database but many Fusion customers do not have a replicated Oracle Fusion DB as it is very expensive. If the customer only has access to BICC, then they need to ask Oracle to run the script in the Fusion DB and send the output.