Tuesday, 3 December 2013

AutoInvoice Line Transaction flex field Error

When importing invoices by the Autoinvoice Import Program , many times we are faced with the error : Please provide a value for the line transaction flexfield.
If we check the setup we see that even though the flexfield has been enabled in the setup the Requeired flag is not checked. How ever Auto invoice when importing the invoice does not check for the required flag being set or not. If the Flexfield is enabled Oracle expects a value to be provided in the interface if the value is not provided the record will be errored out in import.

Moreover the combination of the flexfield values need to be unique , else we will get the error : This line has the same transaction flexfield as another row in the interface table.  For each transaction line, the
               combination of interface_line_context and interface_line_attribute values must be unique

Friday, 8 November 2013

Auto Invoice Error : Please enter quota sales credit percentages that equal 100 percent for this line.

When running the autoinvoice import program you might be faced with the error :
Please enter quota sales credit percentages that equal 100 percent for this line. This error comes if we have multiple records in the table ra_interface_salescredits_all for one invoice line record and the sum of column : SALES_CREDIT_PERCENT_SPLIT is not equal to 100.
 

Thursday, 7 November 2013

Supplier Import Error :POS_SPM_CREATE_SUPP_ERR1

During Supplier Import you may be faced with an error : POS_SPM_CREATE_SUPP_ERR1 . This error is reported if there already exists a record in ap_suppliers/ap_supplier_Sites_All with the same VAT_REGISTRATION_NUM as the current record being errored out.

Oracle does not allow creation of 2 suppliers with the same VAT numbers via supplier import. If needed you can import the suppliers by making these VAT  numbers as null and then hard update the Oracle base table column : VAT_REGISTRATION_NUM with the required value,

Thanks

Supplier Import Error : AP_VEN_DUPLICATE_NAME

When performing Supplier Import you might be faced with an Error : AP_VEN_DUPLICATE_NAME .

The Oracle Supplier Import API has a check that the Oracle system (ap_suppliers) should not have a vendor with the same name as the vendor being created. If a match is found the record will be errored in import and error will be inserted in the table AP_SUPPLIER_INT_REJECTIONS with the error code : AP_VEN_DUPLICATE_NAME

Thanks

AutoInvoice Error : The supplied unit of measure and the primary unit of measure of your system item must share the same unit of measure class

When Importing Data via AutoInvoice we get an error : The supplied unit of measure and the primary unit of measure of your system item must share the same unit of measure class

This error occurs due to the below reasons:

The item has not been assigned to the warehouse for which the data is trying to be imported.

The item UOM definition and the setup are different.

Thanks

API To Update Bank Branch Details

Oracle has provided an API to update the bank branch details:

     IBY_EXT_BANKACCT_PUB.update_ext_bank_branch (
          p_api_version                => 1.0,
          p_init_msg_list              => FND_API.G_TRUE,
          p_ext_bank_branch_rec        => l_bank_branch_rec,
          x_return_status                 => l_chr_return_status,
          x_msg_count                    => l_num_count,
          x_msg_data                     => l_msg_data,
          x_response                      => x_response_rec
                    );

l_bank_branch_rec is BANK BRANCH record type variables. The mandatory parameters to be passed to the API are as below:

bank_party_id => Bank Id
branch_party_id => Branch Id
branch_name => branch_name
branch_number => branch_number
branch_type  => branch_type
alternate_branch_name => alt branch name
bch_object_version_number ,typ_object_version_number ,rfc_object_version_number ,eft_object_version_number => Bank Branch object version number derived from iby_ext_bank_branches_v.

In case of successful Update the API will return 'S'  , In case of errors use the below code snippet to display the error messages:

FOR i IN 1 .. l_num_count
           LOOP
              fnd_msg_pub.get (
                 p_msg_index       => -1,
                 p_encoded         => 'F',
                 p_data            => l_msg_data,
                 p_msg_index_out   => l_msg_index_out);

              fnd_file.put_line(fnd_file.LOG,
                 'Error in Bank Branch Updation  ' || l_msg_data);
              l_chr_val_ret_msg :=
                 l_chr_val_ret_msg || '  ' || l_msg_data;
             
END LOOP;

Thanks

Monday, 7 October 2013

LDT Files For Lookups

The Below Commands can be used to Download and upload LDT files for Lookups:

Download / Generate : FNDLOAD userid/pwd 0 Y DOWNLOAD $FND_TOP/patch/115/import/aflvmlu.lct /server_path/lookup_name.ldt FND_LOOKUP_TYPE APPLICATION_SHORT_NAME ='AU' LOOKUP_TYPE='lookuop_type'

Upload : FNDLOAD userid pwd O Y UPLOAD $FND_TOP/patch/115/import/aflvmlu.lct lookup_name.ldt . Please ensure you are at the server folder where the LDT is placed when running this command.

Tuesday, 10 September 2013

Purchase Order Import Error : Error: Can not derive item_id for the specified buyer item_number or vendor_product_num PO_PDOI_DERV_PART_NUM_ERROR

The above error at the first look gives the impression of the customer item number setup issue. But if you face this error check the below things:

  • Is the item assigned to the receving org specified in the PO
  • Is the item assigned to the IVO of the receiving org.
Take the necessary corrective action and re-import.

Purchase Order Import Error : Unit of Measure (value = EA) is invalid or inactive for item XXXXXX

During the import of Purchase order lines from the table po_lines_interface , we are often faced with the error message:

  • Unit of Measure (value = EA) is invalid or inactive for item XXXXXX
this error is reported for the below reason:
  • The table po_lines_interface has 2 columns : UOM_CODE and Unit Of Measure 
Either of these columns need to be populated
  • If we are populating the column : UOM_CODE then we need to give the code of unit of measure eg : EA in this column
  • If we are populating the column Unit Of Measure  then we need to populate the description of UOM code column in this field. If there is any discrepancy in this the above error will be reported

Thursday, 22 August 2013

Auto Invoice Error : Invalid Value of Conversion Type (CONVERSION_TYPE)

When we run the Auto Invoice Import Program the record errors out with the details Invalid Value of Conversion Type (CONVERSION_TYPE).
This Error occurs because of the below reason :

  1. The Conversion Type Specified is not defined in the system
  2. Some times the user by mistake updates the value of USER_CONVERSION_TYPE of the table : GL_DAILY_CONVERSION_TYPES where as the value needs to be picked from the field CONVERSION_TYPE.


Auto Invoice Error : The supplied unit of measure and the primary unit of measure of your system item must share the same unit of

When importing invoice from ra_interface_lines_All table the user can be faced with an error : The supplied unit of measure and the primary unit of measure of your system item must share the same unit of.
This error message is generally reported because of either of the below reason:

  1. The Unit of Measure specified for the item in ra_interface_lines_all is different from what is specified in the item setup
  2. The item is not assigned to the warehouse for which the invoice line is being tried to be imported


Monday, 8 April 2013

API to Update External Bank Account Details

When an external bank is created in Oracle the user can access the bank details from the view : iby_ext_banks_v.

For each bank records created in the system Oracle will create a party and a party profile too in the tbale hz_oprganization_profiles. Depending on the business the users may be needed to update the bank details in the system , Oracle has provided us with an API which helps us to update banks in Oracle.

IBY_EXT_BANKACCT_PUB.update_ext_bank

   IBY_EXT_BANKACCT_PUB.update_ext_bank (
                          p_api_version     => 1.0,
                          p_init_msg_list   => FND_API.G_TRUE,
                          p_ext_bank_rec    => l_bank_rec,
                          x_return_status   => l_chr_return_status,
                          x_msg_count       => l_num_count,
                          x_msg_data        => l_msg_data,
                          x_response        => x_response_rec);

When calling the API to update the bank the important parameters to be passed are bank_id and object_Version number.

Bank Id is the Id of the bank which the user can get from iby_ext_banks_v.
Object_version_number : Query the table hz_organization_profiles from with the bank_id:

SELECT max(object_version_number)
     INTO l_num_version_number
     FROM apps.hz_organization_profiles
   WHERE party_id = l_num_bank_id;

Pass the object version number to Oracle , In case this value is not passed to the API , you will get an error message, Cannot lock the record in the table HZ_PARTIES , the record is being updated by another user.

In addition to the above values pass the varibales that you wish to update and the API will take care of it :

Sample code Snippet:

IBY_EXT_BANKACCT_PUB.update_ext_bank (
                          p_api_version     => 1.0,
                          p_init_msg_list   => FND_API.G_TRUE,
                          p_ext_bank_rec    => l_bank_rec,
                          x_return_status   => l_chr_return_status,
                          x_msg_count       => l_num_count,
                          x_msg_data        => l_msg_data,
                          x_response        => x_response_rec);   
             
                         --Check for Sucess API
            fnd_file.put_line(fnd_file.LOG,'x_response_rec.result_message '||        x_response_rec.result_message);    
            IF (l_chr_return_status <> 'S')
            THEN
               FOR i IN 1 .. l_num_count
               LOOP
                  fnd_msg_pub.get (
                                  p_msg_index       => -1,
                                  p_encoded         => 'F',
                                  p_data            => l_msg_data,
                                  p_msg_index_out   => l_msg_index_out);
                  fnd_file.put_line (
                                  fnd_file.LOG,
                                  'Error in Bank  Update  ' || l_msg_data);
                            END LOOP;
                ELSE
                   fnd_file.put_line (fnd_file.LOG,
                                               'Bank Updated Sucessfully  ');
              COMMIT;
              END IF;

Sunday, 10 March 2013

Supplier Payment Methods in Oracle

In Oracle, whenever a  supplier or supplier site is Created in oracle , Oracle will automatically create a payee in the system and depending on the data provided a payment method.

Each payee will define the different attributes which are related to all the aspects of payments for that supplier or supplier site.

For each supplier or supplier site the business might want to define the payment methods i.e. mechanism in which the payment will be made, this might the EFT,WIRE,CHECK etc.

When creating a supplier the API will automatically create the payee and payment method for the supplier will be created, provided a payment method is passed to the API . If we pass NULL to the API in the payment method then no payment method will be created.

Even if the payment method is created in the system but if the PRIMARY_FLAG = 'N' then this payment method will not be visible in the front end.

Saturday, 2 February 2013

API to create Code Combination and get CCID

It may not always be the case that Account codes will be created by user from the front end. There may be scenarios sometimes where we need to have programs that will be creating the code combinations.

Oracle has provided the API's that can be used to create code combinations , we will be discussing a couple of them here.

Pre-requisits

  1. When trying to create the code combinations via the API is that in the Key Flexfields setup , for the KFF defined for your Accounting segments the check box Allow Dynamic Inserts need to be enabled, then only will the code combination be created else the API will never create the accounting segments.
  2. User needs to do initialization
  3. The Accounting flex-filed Value sets need to be populated with the values being used in the account being created


Now we will discuss the API's:


  1. fnd_flex_ext.get_ccid , this API will take in the input parameters and return the code combination id of the account segment created. In case the API is not able to create the account segmewnts for any reason or in case of an error the API will return 0.
            API syntax:
            fnd_flex_ext.get_ccid
     (application_short_name      => 'SQLGL',
      key_flex_code               => 'GL#',
      structure_number            => p_chart_of_accounts_id,
      validation_date             => SYSDATE
      concatenated_segments       => allsegments
      );

The API takes in all these parameters as input:
   application_short_name : this is the short name of the General Ledger  Application
   key_flex_code : this is to be hardcoded as GL#
   structure_number : this is to be the chart of account id in which the account
   is to be created
   validation_date : Pass SYSDATE
   concatenated_segments : the account code segments in concatenated format

Once the API is run , if the account creation is successful then the CCID of the account is returned else the program will return 0.

    2. FND_FLEX_KEYVAL.VALIDATE_SEG , the API will take in the input parameters based
         on which the account code will be created , the API returns a BOOLEAN message of
         TRUE : signifying success or FALSE : in case API was not successful 
         API syntax:
         FND_FLEX_KEYVAL.VALIDATE_SEGS(
                                        ‘CREATE_COMBINATION’,
                                        ‘SQLGL’,
                                        ‘GL#’,
                                        chart_of_accts_id,
                                         concatenated_segments,
                                         ‘V’,
                                         SYSDATE,
                                         ‘ALL’, NULL, NULL, NULL, NULL,
                                         FALSE,FALSE, NULL, NULL, NULL);


       If the API is successful the the account segment will be created and the API will
       return a status TRUE , in case any error occurs he the account code creation will 
       fail and the API will return a status FALSE, In case of any error the API will
       populate the Error in the fnd_message queue.
  
       The user will have to retrieve the error message from there to see the error
       occurred:
       l_chr_error_msg := fnd_flex_keyval.error_message

       

Saturday, 26 January 2013

API to Update External Payee

Whenever a supplier/supplier site is created oracle system will automatically create a payee for the supplier and supplier site. Once the Payee is created the user may want to update the payee details.
The API to update the payee is :

IBY_DISBURSEMENT_SETUP_PUB.update_external_vendor

iby_disbursement_setup_pub.update_external_payee 
 (p_api_version => 1.0, 
   p_init_msg_list => fnd_api.g_true, 
p_ext_payee_tab => p_external_payee_tab_type, 
p_ext_payee_id_tab => p_ext_payee_id_tab_type, 
x_return_status => x_return_status, 
x_msg_count => x_msg_count, 
x_msg_data => x_msg_data, 
x_ext_payee_status_tab => l_payee_upd_status 
);

p_external_payee_tab_type is a table type variable of external payees which will take in a number of fields of the table.

p_ext_payee_id_tab_type is a table type variable which will take in only variable : ext_payee_id

When updating an external payee the developer needs to consider the below:
   the api will update all the columns which defined in the record type variable which is passed to the API , thus the developer when assigning values to the record type variable needs to assigne the new values to be updated as well as the old values to the API rec type.

The data updated will be reflected in the table iby_external_payees_all

Saturday, 19 January 2013

Difference between Value sets and Lookups

Value sets and Lookups might look similar and confuse some people but there are some basic differences between the two.

Difference 1
Value sets can be attached to parameters of a concurrent program, whereas Lookups can't.

Difference 2
Certain types of Lookups are maintainable by the users too, for example HR Users will maintain "Ethnic Minority" lookups. Value Sets are almost never maintained by end users, with the exception of GL Flexfield codes. Value sets are usually maintained by System Administrators.

Difference 3
Value sets can contain values that are a result of an SQL Statement.
Hence it is possible to make Value Set list of values dynamic.
On the contrary, Lookup Codes are Static list of values.

Lookups in Oracle

Lookups in Oracle are a collection of values. Lookups are a static collection of codes which are used by oracle for working.

For Example in a form/table if there is a field for Gender rather than storing the values , Male/Female/Unknown the system may prefer to store codes M/F/U . Thus when storing the values rather than storing the description oracle will store the codes M/F/U and display the complete menaning to the user.

Each lookup when defined will have a lookup code and a corresponding meaning for that code. Oracle will internally use codes for working and use meaning when communicating to the user.

Lookup codes are mainly used when working with forms and handling data in the tables.

When ever a lookup is created and entry will be created in the table FND_LOOKUP_TYPES ,

For each lookup type when the value is entered for the lookup entries will be created in the table FND_LOOKUP_VALUES

For the lookups already defined in Oracle each is associated with an application , thus when searching for application specific lookups user should search with the specific application.

Lookups in Oracle are of 3 types:


  1. System: These are lookups which are used internally by the system. Users can see and use the lookup but they cannot disable the existing values or add new values.
  2. Extensible : These are system provided lookups. Users can add their values if they want , but Seeded values by Oracle cannot be changed 
  3. User Defined : User Defined lookups are client specific which are created to meet the business specific customization's. These are created by the users and the users can add new values and disable the older ones.

Sunday, 13 January 2013

Value Sets in Oracle Apps

Value Set as the name specifies refers to a set of values. Theses vales can be used to validate the values entered in a felx-field segment, concurrent program parameters and report parameters.

For Creating Value sets the user needs to navigate to a value set and specify the details of the value set.

The user needs to specify the name of the value set.

The main details that need to be entered are:

Name : The name of the value set

Type: The type of value set

Pop-List : When the number of items is between 1-10
List of Values : When the number of items is between 10-100
Long List of Values : When the number of items is more then 1000

Security: Security type can be applied to a value set

No Securtiy: No security is enabled for the value set
Hierarchical Security : Security rule applied to the parent is automatically applied to the child values
Non-Hierarchical Security : Security rule applied to the parent is not applied to the child values
Segment : Value entered for another parameter of the program is the default value

Format Type : Specifies the type of values that can be entered : Number/char/Date

Maximum size : Representes the Longest possible value

Precision : For numberical valu sets , the number of digits after decimal

Validation Type: Refers to the type of validation applied when values are entered for the fields associated with the value set


  • None : The values enteres is not validated against any pre-defined set of values , the values is only validated against the format type specified.
  • Independent : The value entered is validated against a pre-defined set of values
  • Dependent : The value is validated against a set of values which depend on an indipendent value set .
  • Table: The value entered is validated against against a list of values which are dependent on a table
  • Special and Pair : The value is validated against a set of values in another flex field
  • Translatable Independent and dependent : The value is validated against a previously defined list of values.
Values sets are mainly used when specifying the list of data which can be entered as parameters when running a concurrent program.





Saturday, 12 January 2013

Profile Options in Oracle

Profile Options are options provided by Oracle which helps the user to customize the application. Profile options act as global variables which help in customization of Oracle Applications.

Profile options make the application flexible and helps the business to achieve the desired functionality with minimum hard-coding.


There are many oracle provided profile options which facilitate the working of oracle applications in the desired manner , we will look at it with the help of an example.In a business, the business will be placing orders to procure stationery items , now for a large scale business there will be numerous users placing the request. In order to minimize wasteful purchase the business might want to put a cap on the number of units that can be requested by each employee the business might keep a cap that clerical level employee can request at the max 2 units of any item , managers 5 units and so on.


For this function the business has a custom form , now to implement this functionality the business will have to include all the complex logic in the form to check for this , and in future if any changes are needed the form needs to be changed. To prevent this type of hardcoding and increase flexibility we can use profile options.


Define a profile options : XXPRO_STAT_REQ.In the form we will have a simple piece of code:


IF :oe_line_block.requesed_qty> fnd_profile.value('XXPRO_STAT_REQ') THENmessage( 'You can’t give discount more than ' || fnd_profile.value('XXPRO_STAT_REQ') || '%' ) ;raise form_trigger_failure ;



Thus with the help of profile options the functionality can be easily implemented , now if there are 1000 users in the system , defining the profile option for each user will be an issue , thus the system can assign the profile option at responsibility level and assign this responsibility for requisition to the users.In future when needed to change the value , the user can query the profile option from the front end and make the changes.Oracle provides the functionality to define the profile options at different levels

  1. Site: This field displays the value if set to all the users in the current installation site
  1. Application : This value if set will be applicable to all the users working under the responsibilities defined under this application
  1. Responsibility : This value if defined will be applicable to all the users currently working under this responsibility
  1. User : this value if defined will apply to the current user
Thus if a profile option value is defined at multiple levels then the user level will override the values defined at the responsibility/application/site level and so on


Friday, 11 January 2013

Journals in Oracle


Journal entries are the entering/recording of financial transactions and their monetary value in the transaction accounts of the accounting journal as debits or credits.

Journal entry is strating point of the accounting cycle , Journals are first created for any accounting entry and are then take forward.

For a business any transaction that affects the finances of the business needs to be recorded in the general ledger with proper accounting entries. Oracle creates journal entries for these transactions. Each transaction will have minimum 2 entries one debit and other credit to keep a track of the transaction and its financial impact.

In a complete EBS setup Oracle will receive journal transaction details from various modules:

  • Purchasing
  • Payables
  • Assets
  • Receivables
  • Work In Progress
  • Inventory
  • Payroll
  • Projects
Using the functionalities provided in EBS we can perform a number of actions on journals
  • Creating journal entries
  • uploading journals
  • import journals
  • Reverse journals
  • Post journals
  • Journal inquiry
  • drill down to subledgers
  • Run Reports
Types of Journal Entires:

  1. Basic Journal Entries: This type of journal entry is used for most journal transactions to record revenues,expenses,accruals , adjustsments and re-classifications. 
  2. Reversal Entries: These journals are created for reversing an error, revaluation or encumberance journals. The reverse journals are created either by switching debits and credits or by changing the signs. The reverse entires can be posted in the same or a future acccouting period
  3. Recurring Entries : There might be scenarios where some transaction journals will be created on a recurring basis. Recurring journals can be defined for automatic consolidation and elimination of such journals
  4. Mass Allocation: Journal entries that utlize a single journal entry to allocate revenues,expenses across a set of centers,departments etc.
Journal Creation Methods :

Journal Import: This is one of the commonest method of Journal creation in which the data is populated into the GL Interface by the different modules or third part systems and then journal is created by running the journal import process.

Web ADI : Another method of journal creation is to upload the data via Web ADI through spreadsheets which will create journals.

Manual: As the name suggests is the journal creation method in which Journals are manually created by the users using the oracle screen


Journal parts:

When Journals are created in the system it will be affecting 3 tables: gl_batches , gl_je_headers and gl_je_lines

When ever a journal is created the system will create a journal batch in which this journal will be included..

Each journal will have 1 journal header and 2 or more journal lines.

The journal header will have details of the journal header and the lines will have details of the journal line ie which accounts have been affected by the journal by which amounts and the debit  or credit amounts.


Wednesday, 9 January 2013

Interfaces in Oracle

Any business implementing oracle will generally make use of the available interfaces for integration.
Interfaces are the points in the system from where the data generally enters the system.
Oracle EBS consists of a number of modules each of which interact with each other sharing data and other business information. All the data flow between the modules is done via the interfaces provided by Oracle. For Eg: Data Between Order Management and Account Receivable is shared via the AR Interface , between AR and GL via the GL Interface etc.

Interfaces are tables which can be provided in the oracle package or created as a part of some customization in the system.

Interfaces are extensively used:

  •  in times of data conversion
  • daily interfacing of data from non-oracle and feeder systems
  • seamless integration between different oracle modules


Types of Interfaces on the basis of Data Flow:


  1. Inbound Interface : An inbound interface in the system is the gateway from where data comes into an Oracle module from other oracle modules or from non-oracle systems. The data in this interface is then processed and included into the oracle system. These interfaces might be standard or custom
  2. Outbound Interface : The way oracle system receives data from non-oracle system , similarly the business might also be sending out data out  , for this the system will generate data files which are sent across to other systems. These are outbound interfaces which are again standard of custom.

Interfaces on the basis of standards

  1. Standard Interface/Open Interface: These are the standard interfaces provided by oracle  for data import
  2. Custom Interface: These are custom programs developed as a part of business requirements for data integration and import

                      
Open Interface: 

Oracle Open Interfaces are the standard interfaces provided by oracle for integrating the oracle system to other oracle modules and to interface it with other data sources. Each of the Open interface will be processing the incoming data.

There are some steps in which the data will be processed

  1. Source System Creates Data :  The source system will create the data , this might be in the form of flat file.
  2. Data Load: The flat file having the data needs to be loaded into the open interface tables
  3. Data Processing : The business might have some custom program to pre-process the incoming data and see if all the mandatory fields are there or not
  4. Call the Open interface program : Once the pre-processing if required is done , the open interface program is called , this program will perform all the validations which have been defined by oracle , derive the related fields required on the basis of the data provided process the data and load into the oracle base tables or error them out
  5. Correction: If the record is errored out during the validation by the Open interface, the data needs to be corrected and re-processed
Custom Interface

For business requirements the system might have custom interfaces which take in data from third party systems and process them as per the business customization's

There are some steps in which the data will be processed


  1. Source System Creates Data :  The source system will create the data , this might be in the form of flat file.
  2. Data Load: The flat file having the data needs to be loaded into the open interface tables
  3. Data Processing : The business might have some custom program to pre-process the incoming data and see if all the mandatory fields are there or not
  4. Call the interface program : Once the pre-processing if required is done , the interface program is called , this program will perform all the validations which have been defined by oracle , derive the related fields required on the basis of the data provided process the data and load into the oracle base tables or error them out
  5. Correction: If the record is errored out during the validation by the Open interface, the data needs to be corrected and re-processed

Tuesday, 8 January 2013

Overview of Oracle General Ledger

Oracle General ledger is the core module concerned with the financial reporting of information .All the financial information will mostly end up in General Ledger from where final reporting will be done. General ledger module will Record , Analyze , Manipulate and Report the information.

General Ledger will receive information from all the oracle modules

  1. Order Management
  2. Purchasing
  3. Receivables
  4. Payables
  5. HRMS
  6. Projects
  7. CRM etc.
All the information is recorded , analyzed and then reported by General Ledger

The Basic Accounting cycle of General Ledger is 
  1. Open the period
  2. Receive data
  3. Create Journals/Reverse Journals
  4. Post Journals
  5. Review
  6. Revalue
  7. Consolidate
  8. Reconcile
  9. Run Reports
  10. Close Accounting Period
General Ledger Module will record all the financial information in the form of journal entries

It will create journal entries for all the information coming in an then post it to the final set of books.

General Ledger System can receive information from Oracle Systems and Non-Oracle Systems.

Form Oracle Systems:


Data Processing Cycle

From Non Oracle Systems


  1. Data Will Be uploaded via Spreadsheets
  2. Journals Will be created
  3. Journals will be posted to General Ledger





Monday, 7 January 2013

AR Invoice Correction

When Invoices are created in the system there might be scenarios that invoice get created with incorrect amount , thus the business will need to take corrective action to correct the invoices.

There are various circumstances under which invoice correction  might be required

  1. Under Invoicing
  2. Over Invoicing
  3. Invalid Transactions

Under Invoicing: Under Invoicing as the name suggests refers to the phenomenon in which an invoice is created for an amount less than the actual amount. In such cases since the customer is underbilled we need to have a correction mechanism to bill the customer accurately , the different mechanisms used to correct under invoicing might be
  • Update the Invoice
  • Create a Debit Memo
Over Invoicing:  Over invoicing is the opposite of under invoicing , here we have billed the customer more that the required amount, to correct this phenomenon the strategy that may be adopted is
  • Updating the invoice
  • Create a credit memo
  • Refunds
  • On Account Credit
Invalid Transactions:  There might be a situation in which an invoice is created for a wrong customer or with incorrect information , these type of transactions can be corrected by
  • Voiding the invoice
  • Deleting the invoice

Sunday, 6 January 2013

Accounting Rules for AR Invoice


Oracle Allows to create invoices with certain rules, the rules applied to the invoice are classified as

Accounting Rules: Accounting rules determine when to recognize the revenue for the invoice.Each invoice line can have a different accounting rule

Invoice Rules: Invoice rule determines when to bill the customer

Accounting Rules:


  1. Fixed Schedule: Recognize revenues over a specific number of periods. Revenue can be spread evenly or a percentage can be specified for each period
  2. Variable Schedule: Revenue is recognized by percentage for the first period. The remaining revenues is evenly spread across the number of periods the user specified when entering the AR transaction
  3. Daily Revenue Rate
    1. All Periods: Calculates the revenue distributions across all accounting periods including both full and partial periods
    2. Partial Periods: Used to accurately calculate revenue only for partial periods

Saturday, 5 January 2013

Oracle Receivables Cycle

Oracle Receivable cycle is concerned with the management of  all the receivables of the business. This module keeps a track of all the business receivables and all the receipts in the business.


The basic operations performed in Oracle receivables can be summarized as below


  1. Create AR Transactions
  2. Check for Validity of AR transactions
  3. Complete the AR Transactions
  4. Print the Completed AR Invoices
  5. Create Receipts 
  6. Apply the receipts to AR Transactions
  7. Transfer the details to General Ledger
  8. For the Invalid Invoices , void or delete them

  • Create AR Transactions: This step is concerned with the creation of AR transactions in the system. The AR Invoices can either be created manually form the AR transactions screen or can be created by the Auto Invoice Program by importing the data from the AR Interface. When the AR Invoice is created we have the invoice header , invoice lines are created and customer details are entered.
  • AR transactions Validity: Once the transaction is created the user checks for the validity of the AR transaction , are all the details on the invoice correct.
  • Complete the AR Transaction: Once the AR Invoice is created the Invoice needs to be completed. When the Invoice is completed Oracle will perform a set of validations too to check for the validity of the AR transaction.
    1. Check the invoice has atleast one line
    2. GL Date must be in an open or future GL period
    3. Sum of Distributions must be equal to the header amount
    4. If Calculate TAX is enabled tax must be calculated for each line
    5. If freight is entered it must reflect to the freight account  
         Once the invoice is completed the below activities can be performed
    1. Payment schedules are created
    2. Invoice can be transferred to General Ledger
    3. Transaction can be printed          
  •  Print the Completed AR Invoices : The business can print the AR Invoice if required for  internal tracking or sending to customer
  • Create Receipts: On receiving a payment from the customer a receipt is create in the system to keep a record of it
  • Apply Receipts: Once the Receipts are created in the system we need to apply the receipt under an invoice to mark the invoice as paid. else even if receipts are received but not applied to an invoice the Invoice will always remain in an open status and will always be reflected as unreceived.
  • Transfer the details to General Ledger: In order to generated all the financial statements all information must be transferred to General Ledger .
  • Void / Delete transactions: If any invoice is found to be incorrect by the user , they are either voided or marked for deletion from the system

Auto Invoice Import Process

Auto Invoice Import is a standard utility provided by Oracle to create Receivable Invoices. The utility is used to create invoices,credit memos and debit memos in Oracle.

Invoices can be created from:

  1. Order Management
  2. Projects 
  3. Loans
  4. Services 
  5. Lease Management
  6. Property Manager
  7. Non Oracle Systems
When Invoices need to be created the Invoice information is entered into the AR Interface tables:
    1. RA_INTERFACE_LINES_ALL
    2. RA_INTERFACE_DISTRIBUTIONS_ALL
    3. RA_INTERFACE_SALESCREDITS_ALL
The Autoinvoice import program will pick up the eligible records from the table and invoices are created for the eligible records

When the program is run to create the invoices the program will

  1. Order and group the lines --> Specified in the frouping rules setup of AR
  2. Contingencies are assigned
  3. Legal entity is grouped
  4. Tax Engine is called to caluclate the tax
  5. Sales Credits is calculatted
  6. GL Data is determined
  7. Accounts are assigned
  8. Transactions are batched
  9. Valid records are successfully processed to create invoices
When creating invoices via the autoinvoice import program some records might error out in processing due to errors in data or during processing. All the records that error out in processed need to be corrected and re-processed again

Oracle has provided standard screens to see all the records erroring out in interface lines , via the Interface Errors screen. This screen shows all the errored records , the user needs to correct these data and re-process them

For the records which are successfully processed Invoices are created in the system which can be seen from the transactions window and from the backend via the tables:
  1. ra_customer_trx_all
  2. ra_customer_trx_lines_all
  3. ra_Salescredits_all