Customising the EBS GL Balances to EPM Cloud Connection

In my first blog on the EPM Integration Agent, I covered pulling EBS GL Balances from on-premises Oracle EBS to EPM Planning, using the out-of-the-box Oracle connector in data management.

However, as described, there are a few shortcomings with the connector which make it more desirable to use a custom SQL query to pull EBS GL balances into EPM. The main issue being that the Oracle data load rules can only be run for a single Ledger and Period each time, making it difficult to update multiple historic periods at once and inefficient if there are multiple Ledgers in Oracle.

Fortunately, it is possible to retrieve the full ‘EBS GL Balance’ SQL query and tweak it, rather than having to start from scratch (thanks Oracle!)

This blog will cover the below points, detailing a few simple ways that the SQL can be adapted to improve usability:

  1. Retrieving the original EBS GL SQL query
  2. Updating SQL WHERE Criteria to:
    • Remove the Ledger filter, allowing import of all Ledgers at once
    • Use a Like query for the Period, rather than an Equals
  3. Adding a field to the query for the correctly formatted Period name, to allow multi-period retrievals using default period mappings
  4. Setting up the custom integration

1.       Retrieving the EBS GL SQL Query

Firstly, we need to extract the SQL query that is used by the Oracle EBS GL connector. To do this, you will need to setup the connector as described in my first blog: https://lydia-maksoud-epm.blogspot.com/2020/07/loading-gl-balances-from-ebs-to-epm.html

Run the data load rule and navigate to the Process Details page. Open the log in notepad and copy the Original Extract Query section, starting with a SELECT statement.

2.       Updating SQL WHERE Criteria

The Ledger and Period filters in the data load rule are used in the SQL WHERE conditions at the end of the query, as below:

-- Original SQL Conditions
AND gld.NAME = ~LEDGER~
AND PERIOD_NAME = ~PERIOD~

 To remove the Ledger filter, we can just remove the whole line referencing the Ledger variable (in italics above). The Ledger field can be referenced in the import format to allow mapping and filtering by Ledger, rather than having to change the Ledger filter each time or have multiple rules to cover exporting multiple Ledgers. Make sure to add this in the Import Format and Data Load Mappings area if required!

For the period, we need to update to use a LIKE criteria, rather than equals. In this instance, we also changed the variable name, so the new filter criteria are as below:

—New SQL Conditions
AND PERIOD_NAME like ~PERIOD_NAME~

Now, instead of having to specify a single period, we can use wildcards. For example, by setting the filter to % the query will import ALL periods, rather than just one period.

3.       Adding field for Data Management Period name

The final issue we face is that the period format in Oracle EBS is MMM-YY (e.g. JAN-21), whereas Data Management default period mappings use format Mmm-YY (e.g. Jan-21) and unfortunately, these mappings are case sensitive.

So, to allow multi-period loads we have two options:

A.      Setup an explicit calendar to map the Oracle EBS period to the EPM period –  this is not ideal as it would require additional maintenance

B.      Or, we need to convert the period to be in the correct Mmm-YY format as part of the SQL query

For flexibility, we’re going to go with option B here. To do this, we add a field to the SQL query which converts the original EBS period from MMM-YY to Mmm-YY format, using the INITCAP function, as below:

-- SQL modified with the INITCAP function to change the case of the period from MAR to Mar
INITCAP(gb.PERIOD_NAME)          as "Period Name",
gb.PERIOD_NAME          as "GL_Period", 

We must keep both period name formats as the drill-through requires the all-capital format to be referenced in Oracle EBS (blog to follow on EBS drill-through setup 😊) 

4.       Setting up the Custom integration

Once the SQL has been edited, run the query against the EBS tables to test, remembering to replace the ~PERIOD_NAME~ variable with a real period value or use a wildcard %. Right click and export the output to Excel. Remove the data, leaving the column headers only and save as a csv format.

Note: the step to create the csv headers can be done manually instead, but the column names must match the SQL query headers exactly (be careful of typos in the original Oracle SQL!)

Then, navigate to Data Exchange -> Actions -> Query and create a new query to hold the SQL. Add some commentary at the beginning of the query (using --), to explain the purpose:

Once we have the query and the csv headers, we can setup a custom data source using the generic ‘On Premise Database’ source system type, rather that using the ‘EBS GL Balance’ type.

 

Upload the csv containing the column headers and make sure to reference the above SQL query in the EXTRACT_QUERY section of the application filters, along with the EBS connection details.

I won’t go into detail here, but rather refer you to another of John Goodwin’s excellent blogs on the subject: https://john-goodwin.blogspot.com/2019/10/epm-cloud-integration-agent-part-3.html

Edit the application filters to add the PERIOD_NAME filter. This will be displayed at Rule level, as below:

Then in the Import Format, we can reference the correctly formatted Period Name column to be used as the load period. This will then be mapped to the EPM period using the default period mappings, as normal. We also import the GL_Period as an attribute for use in the drill-through later and reference the Ledger Name for mappings (as described in step 2).

Map the amount and the rest of the dimensions:

Add a new Data Load Rule, referencing the query import format.

The Period Name filter will display automatically in the load rule – this will require the EBS period format (e.g. JAN-21) or a wildcard (e.g. %-20 to import all 2020 months).

Note: although the condition says Equal here, the filter is in fact using a like condition in the query.

Setup the data load mappings as required and import the data as normal.

To import multiple periods, set the period name filter as % in the data load rule and select different start and end dates when importing – the periods will be mapped to the correct place in EPM using the default period mappings.

Hope that helps and let me know how you get on!

For more useful Oracle EPM Cloud and NetSuite ERP blogs posted by my colleagues, see the Brovanture website HERE 😊


 

Comments

  1. Excellent read, Positive site, I have read a few of the articles on your website now, and I really like your style. I really appreciate your work.If you require aboutfree company registration in india in bangalore | one person company registration in bangalore please click on it.

    ReplyDelete

Post a Comment

Popular posts from this blog

Loading multi-period row data files using Data Management

Loading Actuals from Fusion ERP Cloud to PBCS

Executing Smart View Retrievals using VBA