Skip to main content

Account Payables Complete Flow (Invoices, Payments)

PAYABLES(ABOUT INVOICES USEFUL INFORMATION)

ABOUT INVOICES
--------------
 /*ACCOUNTING METHOD , ACCRUAL OR CASH :
     So do you set the accounting method only at the Payables,Receivables levels,
  not at the GL Level. I believe so,because of those settings,payables and
  receivables will generate the journal entries accordingly.

 When we create an invoice we initially create a invoice batch and then create
 invoices in that batch. While creating invoice batch, we provide the control amount
 and control count (the intial batch amount and intial batch count),payment terms,
 type of invoice(like PO default, standard,CM,DM etc), pay group. These invoices go into
 the "ap_batches_all" table. However some of the above fields are optional at the batch
 level and can be specific at the invoice level.

 Having entered an invoice batch, we enter the invoices in that batch and enter
 the supplier information currency. Here the values mentioned at the batch level
 will default at the invoice level which can be changed at the invoice level. All
 the invoices go into the "ap_invoices_all" table.

 Each invoice will have distributions and each distribution (which could be either
 item, tax, frieght charge) will correspond to a particular gl_account and will
 be stored in "ap_invoice_distributions_all" with the corresponding code_combination_id
 in the table.

 Having created an invoice the invoice needs to be validated,payables accounting
 process and approved(may not be required). For validating an invoice it is
 important that the control amount at the batch level sums up to the sum of the
 individual amounts of the invoices. The control count at the batch level should
 be equal to the number of invoices in that batch.
  The invoice can be validated by pressing the validate button.
  Make sure there are no holds on that invoice.i.e holds are 0.
 And only the validated invoices will be paid or payment applied.

 As mentioned before, the invoice is distributed on item,tax,freight etc), where
 we mentioned for each distribution which account it should go to i.e the item should
 go to account1 and tax should go to another tax related account.
    Or we can create a distribution set where we mention the percentages of each item,
 say the 70% of the invoice item should go to the account1 and 30% to account2.etc
 and assign that distribtuon set to that supplier.
 once this is done, for every invoice corresponding to that supplier ,if we select
 that distribution set, the above %'s are automatically applied.

 One feature of the Oracle Payables is that, the AP can also treat the employees
 in a particular company as suppliers (i.e typically the suppliers send the invoices
 which are paid for) similarly the employees should also be paid for the services
 they render every pay period and what should be the employees payment terms.

 Accounting in Payables Transactions.

 There are two document classes in Accounts Payables which can give rise to accounting
 transactions.
   Invoice  (creating Invoices)
   Payment  (Issuing Payments).

 Entering an Invoice :
  An invoice increases the suppliers account balance by the invoice amount.
  Once the invoice is completed,

 The corresponding journal entries will be posted to the General Ledger in the
 next GL transfer. As an ex, the following are the entries created for an invoice
 entered for amount $200. Hence the three main accounts that are updated in an
 invoice entry are
 
 Account    Derivation                      DR      CR
 --------   --------------------------------------------------------
 Liability    : Defaulted from the Supplier site ,otherwise can be entered  :     $235
            at the invoice batch level  
 Expense/ Asset  : Defaulted from the Purchase Order,otherwise entered at the  : $200
       invoice level.
 Tax    : Defaulted from tax name,can be overwritten during invoice.  :  $35

 */

 select batch_id,batch_name,invoice_currency_code,payment_currency_code
     terms_id,gl_date,invoice_type_lookup_code,org_id
 from ap_batches_all
 where  batch_name ='mybatch9'

 select * from ap_terms_lines  -- ap_terms_tl
 where  terms_id = 1205

 /* Actually there is a payment term specified at the batch level and as well as the invoice
    level. However invoice level take precedence. When you dont mention anything at the
    invoice level/batch level, the term from supplier will default. Since invoices come from
    suppliers, there is a chance that two invoices from two different suppliers might have
    the same invoice number, and hence internally we assign a voucher number. For the same
    supplier u cannot have two invoices with the same invoice number.*/
 SELECT * FROM ap_invoices_all
 WHERE 1 =1
 and   batch_id = 10065
 --and  invoice_num = 'myinv1'
 --where invoice_id = 52989

 -- Just like AR, in AP as well, the payment schedules table will have the due dates etc.
 --Even without any payments,once an invoice is created, it will figure in this table.
 select invoice_id, gross_amount, amount_remaining, due_date,payment_method_lookup_code,
     batch_id,org_id,inv_curr_gross_amount
 from ap_payment_schedules_all
 where invoice_id = 10544

 SELECT * --dist_code_combination_id
 FROM ap_invoice_distributions_all
 WHERE invoice_id = 10663

 /* While creating an invoice batch we can provide the liability account and
  while creating the invoice we provide the expense accounts for the main item
  and frieght or tax purposes (called distributions) */

 select * from gl_code_combinations -- 1012
 where segment1 =01
 and segment2 = 0000
 and segment3 = 0000
 and segment4 in (73100,67170,21330)
 and segment5 = 0000
 and segment6 = 0000
 and segment7 = 0000
 and segment8 = 0000

 /*Default Expense or Charge Account for AP Invoice , Distribution Sets:
 We know that the default liability account will come from the Financials Options and which is
 shown at the invoice header level(liability account field can be sometimes hidden and hence
 should be unhidden.
     There is also an expense account which is at the invoice distribution level. In general
    this has to be entered manually at the dist level. However this can be defaulted by defining
 a distribution set and associating that distribution set at the supplier site level. Hence it is
 important that DISTRIBUTION SETS ARE ONLY FOR CHARGE ACCOUNTS NOT LIABILITY ACCOUNT.

 */
   select *
   from   ap_invoice_distributions_all

 /*To approve or generate accounting entries online , ensure that the following setting is done,
    setup => options => payables => invoice tab => Allow Online Validation.  */


 /*Hence after this is done, we want to transfer all this information into the GL,
 because it is a ledger system. AP,AR,Assets are the feeder systems(or subledgers)
 in financials and they will be transferring the txn's to GL to reflect the accounts
 correctly. From payables to GL, this can be done by "Payables Transfer to GL" program.

 So the various steps the payables invoices will go thru before they are transferred
 to GL are given below
 */
   Invoice Validation,
   Payables Accounting Process,
   Invoice Approval workflow and then
   Payables Transfer to gl(which involves payables transfer,journal import and posting).

 /*So once the payables txns are transferred (gl_je_headers and gl_je_lines) tables
  are populated and when the txns are posted, the gl_balances tables is updated.
  The gl_balances tables is a huge table which consists of an entry for each account
  or code_combination_id, when the txns are posted, the corresponding accounts in the
  invoice distributions are updated accordingly.*/

  /* ACCOUNT GENERATOR Role in Payables & Projects :
  Just want to talk about ,what is the role of account generator, say while
  creating an invoice, For ex;liability and expense account are already specified
  as part of the system options/distribution sets and hence it has to copy it
  straight from that.

  What I mean to say is that unlike AutoAccounting in AR(or FA),which has to build each
  segment and the combination, the Account Generator in AP does not have to build
  each segment,correct? The only place where I saw account generator work, is when
  you specify a project information at the invoice distribution level, then it will
  rebuild the distribution. Other than that, the Account generator does not really
  have to build segments of the code combination, other than copy from the options.
 
  So for ex, if you specify project information in the distribution level, there is
  a standard workflow functionality to build the combination. However even this
  can be customized by developing our own workflow functionality and specifying at
  this location, (from the General Ledger responsibility)
   
    Setup => Financials => Flexfields => Key => Accounts
 
  This will open the form "Account Generator Processes",query for the application
   "General Ledger" and the flexfield title "Accounting Flexfield" and for your
  corresponding structure. Here you can see for the item type "Project Supplier
  Invoice Account Generation", what is the process name. THe default value is
  "Generate Default Account",which is the standard value. Any customized workflow
  process can be specified here.
 
 
 
  INVOICE VALIDATION :
  --------------------
  /*The Invoice validation program does a bunch of things when it starts validation,like ,
    Matching
    Tax
    Distribution
    Period Status
    Exchange Rate
 
  so while it is matching the invoice, what kind of matching it uses 2-way,3-way
  or 4-way. Typically when we create an invoice we provide the supplier and supplier
  site information from where we are receiving that invoice. So the system will
  decide how to do the Matching based on the setting at the supplier site level.
  If at the supplier site, the Invoice Match Option is set to Purhcase Order,then at the
  time of validation, the invoice is matched against the purchase order.
  Another interesting point is that, when we create a purchase order, at the
  distributions the invoice match option is also specified which basically defaults
  from the supplier site,however we can change that accordingly.
  Hence as we see, there are two important parameters
    Invoice Match Option : PO (or Receipt)
    Match Approval Level : 2-Way (3-Way or 4-Way)
 
   2-Way :  Invoice Quantity <= PO Quantity ; Invoice Price <= PO Price;
   3-Way :  2-Way   +   Invoice Quantity <= Receipt Quantity (by the tolerance level)
   4-Way :  3-Way   +  Invoice Quantity <= Accepted Quantity (by the tolerance level)
 
  (Interestingly there is also a Invoice Match Option that you can set at the Financials Options
     Setup => Options => Financials Options )
 
  The different kinds of scenarios that are available are
   We can have 1 PO , 1 Receipt  => 1 Invoice
   We can have 1 PO , 5 Receipts => 5 Invoice
  */
    -- The validation flag gets updated in the ap_invoices_all table
   
    select * from ap_invoices_all -- approval_status?

 -- Invoice Matching with Purchase Order and 3-way Matching.

 /*
 Generally, when an invoice is raised and there is a corresponding matching
 PO, then the po_distribution_id column in the ap_invoice_distribution will
 be not null, and that is the best way to identify invoices that have been
 matched with PO, even though there is a column by name match_status_flag.
 Once an invoice is raised against this PO, the quantity billed and the amount
 billed columns will get updated with the invoice prices).
 */

 select a.quantity_invoiced,a.unit_price ,c.quantity ,c.unit_price,
     c.unit_price - a.unit_price price_difference
 from   ap_invoice_distributions_all a,
     po_distributions_all b,
     po_lines_all c
 where  a.po_distribution_id = b.po_distribution_id
 and    b.po_line_id   = c.po_line_id
 and    a.accounting_date  between trunc(sysdate -1) and trunc(sysdate-1) + 0.99999 --- 60354
 and    a.unit_price   < c.unit_price
 and    a.po_distribution_id is not null

 /* So basically the following query should be able to give us what is the
 corresponding PO from the invoice.  This is very much similar to the relation
 that we have between requisition and the PO i.e by distribution id.
 */
     ap_invoice_distributions_all.po_distribution_id = po_distributions_all.po_distribution_id
 
 So if the Matching fails, then it will put the Invoice on Hold. We can run the
 Invoices on Hold report to see what invoices are hold  

/* PAYABLES ACCOUNTING PROCESS ;
 --------------------------------
 ACCRUALS :
   We know that the two main accounts that get updated in Accounts payables when an invoice is
      created are LIABILITY(and EXPENSE).That is when you create a stand alone AP Invoice,
   with out any PO matched, where you will manually enter the expense account. The dists
   can be seen from the query.
 */
   select * from ap_invoice_distributions_all

 /*However let us take the case of a PO received and an invoice is created by matching the PO.
   When the PO is received, the following accounting entries gets generated
   at the time of receiving

  Receiving Inventory (Dr)
  AP accrual (Cr)
 
 Later when AP invoice is created and matched.
 
  AP Accrual Acount Dr
  Trade Payables Cr
 
 Here one thing we need to notice is that, once you match the PO, the account is auto
 matically defaulted with the accrual account from PO.
 
 Concept of Accounting Event :
 An accounting event is a payables transaction that results in an accounting impact.
 So for the two document classes of Invoices and Payments, the accounting events would be

 Invoices => Invoice, Invoice Adjustment, Cancellation, Prepayment application, Unapplication.
 Payments => Payment,future dated payment, adjustment, cancellation, clearing,unclearing.
 
 So having created the accounting entries we can expect the data in these two
 tables with the balances being updated for the liability and the expense
 accounts. We track this by using the code combination id.*/
  */

 /* In the headers table we will not have invoice references.Interestingly we
 would expect the gl transfer flag in the lines,but it is in the headers table here */
 select * from ap_ae_headers_all
 where ae_header_id = (
    select distinct ae_header_id
    from   ap_ae_lines_all
    where  reference2 = 10407)

 /*Here in the lines table, the invoice references are there from reference2 (invoice_id)
  or from source _id */
 select ae_header_id, ae_line_id, code_combination_id,entered_dr, accounted_dr,entered_cr,
     accounted_cr,creation_date, last_update_date
 from   ap_ae_lines_all
 where  reference2 = 10407
 -- and source _id = 10467
 -- and source_table in ('AP_INVOICES','AP_INVOICE_DISTRIBUTIONS')

    select ae_header_id, ae_line_id, code_combination_id,entered_dr, accounted_dr,entered_cr, accounted_cr
       ,creation_date, last_update_date
    from   ap_ae_lines_all
    where  creation_date >= trunc(sysdate)
    -- and   code_combination_id in (1012,4583,5933)


 /*INVOICE APPROVAL WORKFLOW :
  ----------------------------
 To setup the invoice approval workflow in AP, you need to use the Oracle
 Approvals Management(AME) to define the required rules. And if you want the
 HR hierarchy to be used for the AME,then you need to define the logic
 accordingly in OAM.

 manual holds after matching can be released.
 interestingly at the payables invoice level, no inv items are specified=> and hence no lines only
 distributions probably
  */
  select * from ap_invoices_all

 /*Payables Transfer to GL :
 ****************************
 It is very important to understand that Payables Transfer to GL will result in failure if
 the accounting combination given is invalid. What this means is the if say for the expense
 account combination if you give an asset account, the payable transfer program will fail.

 Another thing I noticed is that some times, the parameters set of books id, are not displayed
 and hence they dont have any value,so they are failing, in which case enable and display them
 and then run again.
 */
 select * from gl_interface


   /*Supplier Balances : Just as in AR (where the customer balances are given by the
   ar_payment_schedules_all),the supplier balances are given by ap_payment_schedules_all
   table. However there is no vendor id and hence the query to get the supplier
   balances are given by. */
 
   select * from po_vendors
   where vendor_name = 'mysupplier' -- 57175

   select invoice_id, gross_amount,amount_remaining
    from ap_payment_schedules_all where invoice_id in (
   select invoice_id from ap_invoices_all where vendor_id = 57175)

 
  /*ABOUT PAYMENTS
  ---------------
   Having created the invoice batch and invoices,we now create a payment batch
   and possible give the invoice batch name as the source for this payment. The
   different phases a payment will go thru are
 
        New
   Selecting
     Built
     Rebuilding

     Formatted
     Confirmed (payment batch)
     Create Accounting
 
  All these statuses we can progress thru from the Action button.    
      A caveat is while creating a payment batch, we have to provide the
    documents which we may have to create using the bank ,branch, account form. */
 
  /* Initially when we create a payment batch, we create a batch which corresponds
  to a group of invoices from a particular supplier or from a particular pay group.
  After this, from the actions  button, we select "select invoices and build
  payments options" and choose this action to be performed. what this means is that,
  we want a payment to be made for the amount equal to  the sum of all the invoices
  corresponding to that particular supplier chosen or corresponding to all the
  suppliers of a particular pay group.
           Conveniently we can also give a invoice batch created earlier and it
  would pick only the invoice corresponding to that particular batch.The requery
  batch will show the different statuses like Selected,Built etc.
 
  Also while creating a payment batch, we provide the document of payment. this is
  +done as follows. We can go to the (setup,payments,banks ) and then create a
  bank, bank branch and then bank account. While creating a bank account, we provide
  the GL account corresponding to the cash. That is when this document is encashed,
  this particular GL account is updated. So having created successfully a bank
  account, we can create the payable documents, where we create a payable document
  (we also provide what kind of format it is) and provide all the relevant
  information.(like the starting and ending check numbers in case of check payment method)
 
  So when this particular action is completed we do get a payment total which is equal to this sum.
  and the status of the payment batch is "Built".And then we can "confirm" this batch as well ,upon
  which the status changed to "Confirmed".
 
  Now when look at the "payments" button for this particular payment batch, then
  we would see the diversification of this amount into different supplier amounts.
  What this means is that for each supplier how much amount is owed is provided.
  In this screen we can also look at the division of this grand amount into
  individual invoice amounts, by pressing the invoices button.
  */
 
  --Actually the payment batches are called checkrun_names and they are stored in this table.
    select checkrun_name,bank_account_name,status, payment_method_lookup_code,org_id,
        start_print_document,end_print_document,first_available_document,last_update_date
  from ap_inv_selection_criteria_all
  order by last_update_date desc
 
  /* Hence when we make payments, the liability account(5933) in Payables will get
     debited while the cash clearing   account will get credited (4583) */
 

   /*Automatic Payment Programs :
   *****************************
    In Oracle Payables, we can use the "Automatic Payment Programs" window to define
 the payment programs that you use to build,format payments or for creating a
 remittance advice.
 
   Oracle Payables defines 3 payment program types
 1 standard program for building the payments => Build Payments  ,
 13 standard programs for formatting the payments => Format Payments (Standard Oracle),
 1 standard program for creating a separate advice for payments => Remittance Advice.
 
   When we define a payment format, we associate the above defined programs (for
   build,format and remittance advice) and some other options.
 
   And when we create a payables document ,we associate the above created payment
   format and specify some other parameters like the min and max document numbers.
   So the relation is
      (Payment Formats,methods) => Payment Programs => Payables Documents
 
   Some information about the document numbers : the document numbers can be
   associated with any kind of payment method (i.e not necessarily for checks).
   However let us take the simplest case of checks.
   We know that in AP, we define banks, branches accounts and for any particular
   bank we can define the payables documents. In the case of checks,

   LAST_USED => If you are defining a new payment method,then you usually enter
 the value of 1 as minimum. Let us say you already defined this document
 number. After this some payment batch has used this particular payment
 method. Since it has used that, the document for that payment batch will
 be 1. Also during that entire process of building,formatting the payments,
 no other payment batch can use this particular document. Also once any
 payment batch starts using this document,it will update the last_used
 column  to the appropriate value(i.e to value 1) and the value is not
 updatable until that batch is done processing. After that we can update
 that value again.  
   LAST_AVAILABLE => is the document number that is the last available number,
 beyond which we cannot use.
 
 
   /* When you actually start creating a payment batch, the bank account information is
   automatically defaulted. And it comes from the payables options level. Now  to get a bank
   and branch from the bank account name, run this query.*/
 
    select * from ap_bank_accounts
 WHERE bank_account_name like 'BofA_CN_INTERNAL' --'110 US 2788 BOFAUS3N USD'
   
 --
    select *
 from ap_bank_branches
 where bank_branch_id =48000
 
     /*A bank account is striped by org_id i.e by the operating unit id,but not the bank branch.
     That is if you have banks
     in different countries, then just having a bank account in US will not do.
      You should create a bank account corresponding to that particular operating
 unit and then transact.
     An exception is Wire method :
        Wire method of payment is a type of payment which you do outside of payable system and once
     payment is done then based on document sent by bank you record it in payable system and hence
     payment batch is not possible with wire transfer when you enter in the system,by which time
     the payment is already done and hence no need to tell the system which invoices to be selected.
     */
 
 PAYMENT BATCHES :
 ----------------

     begin
     fnd_client_info.set_org_context(fnd_profile.value('ORG_ID'));
     END;
   
 --BUILDING THE PAYMENTS :
 ------------------------
 /*Building is the process where the selection of the invoices & building
 for that batch happens.

 Only invoices which match the criteria of the payment batch will be selected.
  Basically we must ensure on the payment batch for the following things ,:
 
     PAYTHRU DUE DATE, PAY GROUP, PAYMENT PRIORITY, PAYMENT METHOD*/
 
  --Actually the payment batches are called checkrun_names and they are stored in this table.
     select checkrun_name,bank_account_name,status, payment_method_lookup_code,org_id,
         start_print_document,end_print_document,first_available_document,last_update_date
   from ap_inv_selection_criteria_all
   order by last_update_date desc
 
   /*If you change the payment method code on a supplier , then all the existing
    invoices/batches will not change, you will have to manually change the payment method
 code. However all subsequent changes will have the new changed payment method code.*/
 
   different payment terms on batch level and invoice level.

 see and explore what exactly the pay thru date means.

  -- All the invoices that are selected for the payment batch are from this table.
     select * from ap_selected_invoices_all
  where  checkrun_name = 'mypbatch7'
   order by last_update_date desc
   
 -- We can also check what is the check number that is used for this payment here.
     select *
  from  ap_selected_invoice_checks_all
    -- where  checkrun_name ='mypbatch47'
  --and    status_lookup_code = 'UNCONFIRMED SET UP' order by selected_check_id
     order by last_update_date desc
 
FORMATTING THE PAYMENTS :(Very Important Step)
-------------------------
 /*The next step after building the payments is formatting. As mentioned before, there are
 13 different standard format programs which oracle provides. And we can create as many
 as we want as well. When you run the format program, the program that is specified
 in the payment method(like check etc),which you specify in the payment batch will be run.
    */
     From the bank account =>
    Payables document =>
       document name =>
          (payment format,method) =>
     BUILD and FORMAT program name.
 
     /*Usually in the case of the check payment , the remittance advice program is part of the
 Format program and hence we dont need to run any separate program. However for the payment
 methods like EFT, then there will be a separete remittance advice program which will be
 running.
        And once the payments are built,formatted and confirmed, the checks last_used value will
 get updated as mentioned earlier,*/
 
  /*Basically formatting means (nothing much happens on the back end side) it
  searches for certain options and shows how the output or check will look like
  and based on the parameters like stub first or last, print check stub or not
  it will show us how the check looks like in the output file once the program
  completes. The following query gives pretty much the formatting options,
   */
 
  SELECT aisc.checkrun_name,
         acf.separate_remittance_advice, acf.stub_first_flag,
         acf.print_check_stub, aisc.check_date
    FROM ap_invoice_selection_criteria aisc,
         ap_check_formats acf,
         ap_check_stocks acs
   WHERE aisc.checkrun_name = 'mypbatch7'
     AND acs.check_stock_id = aisc.check_stock_id
     AND acs.check_format_id = acf.check_format_id
 
   -- Even though the table name says check formats all the payment formats are
   --stored in this table.
   select stub_first_flag,print_check_stub, separate_remittance_advice,invoices_per_stub
   from ap_check_formats
   where name like 'Standard Check Format'
   order by last_update_date desc
 
   /* Basically check stocks is not transaction dependent. It tells you what is the
   starting number and ending number */
   select * from ap_check_stocks
   order by last_update_date desc
   
   /* "ap_selected_invoice_checks_all" is a temporary table that stores payment
    information during a payment batch. Payables inserts into this table when
 you build payments in a payment batch. There will be one row for each payment
 issued during the current payment batch. When you confirm a payment batch,
 your Oracle Payables application inserts these payments into"ap_checks_all"
 and creates a payment file. And then it deletes from the
 ap_selected_invoice_checks_all*/
   
   select *    --
   FROM ap_selected_invoice_checks_all
   order by last_update_date desc
 
   /*I changed the option in the payment format from before document to after document,
   and then the invoice information is printed below the check now.So the formatting
   gives us with a lot of options like how the check document looks like.*/
 
   --
    select * from ap_checks_all
    order by last_update_date desc
   
    select * from ap_checkrun_conc_processes_all
   
    select * from ap_checkrun_confirmations_all
   
     
 /* Just like AR, in AP as well, the payment schedules table will have the due dates etc.
   now we can see the amount remaining is zero,once the payments are made for the invoices.*/
 select invoice_id, gross_amount, amount_remaining, due_date,payment_method_lookup_code,
     batch_id,org_id,inv_curr_gross_amount
 from ap_payment_schedules_all
 where invoice_id = 10544

 --And from the form, we can check the invoice payments from
  Invoices => View Payments
 
 
/*CONFIRMING THE PAYMENT BATCH
----------------------------
 Basically when we format the documents at that point of time, we can print the checks.
 This is how it works.
      Basically we load the check documents in the printer, these check
 documents will already have the numbers on them. Now when the printing of checks completes,
 then we know what got printed successfully and what not. Let us say one particular check,
 say 1005, is damaged ,then we can tell the system during the confirm process. That is we
 choose the value "skip" and provide that number,so that system will ignore that. We also tell
 which got printed successfully.  After all this is done, the last_available and last_used ones
 will get updated successfully.

 The confirm payment batch will print separate payment document for each
 supplier ,otherwise it will just print one payment document. is that true.
    */


    /*ACCOUNTING FOR PAYMENT BATCHES.
    We have seen that we progressed the payment batches thru building, formatting,
   confirming etc (regardless of the formatting method used). Payment batches
   can be accounted only after the corresponding invoice batches have been accounted
   for. And payment batches can be accounted only after they have been confirmed.
    */

    select *
  from ap_accounting_events_all
  --where event_type_code like 'PAYMENT%'
  order by creation_date desc
 
      select *
  from   ap_ae_headers_all
  order by last_update_date desc
 

   /*Pay Alone Invoices :
 -------------------
 Pay Alone Invoices : When the pay alone check box is checked at the invoice
   level(which actually defaults from the supplier site level and can be changed
   at the invoice level), then payables will create a separate payment document
   for that invoice. That is when you build the payments it does not include
   any other invoices other than a pay-alone invoice. If there is pay alone
   and non pay-alone invoice, then pay alone invoice will be built first.*/

   /*SINGLE PAYMENTS :
   -------------------
 The three different types of single payments are
     Manual Payments
     Quick Payments
     Refunds.

    One of the major difference between the single payments and batch payments is
   that in the single payments you do not have the process of building the payments.*/
 
    /*MANUAL Payments : One main functionality of the manual payments are when
 the payment has already been made,then you come to the manual payments
 screen and record that payment. So it is basically after the fact and
 you mention the invoice for which it is paid so the invoice balance is
 reduced. Since there is no invoice selection criteria and you directly
 mention/enter the invoices they do not go into the table
 ap_inv_selection_criteria and they go to ap_invoice_payments_all.
    We can identify such payments from the following table using the invoice id,*/

   /* Unlike in the case of batches, where the checks are inserted into ap_checks_all
   at the time of confirming. Here at the time of creation itself the checks are
   inserted into ap_checks_all,all at once. */
 
   select payment_type_flag, payment_method_lookup_code,check_id,check_number
   from ap_checks_all
   where check_number= '1000009'

   -- Put the above check id here to get payment/invoice information.
   select invoice_payment_id,invoice_payment_type, accounting_event_id, cash_posted_flag,check_id,
   invoice_id,amount,period_name ,accounting_date
   from ap_invoice_payments_all
   where check_id = 10480  

   SELECT *
   FROM ap_lookup_codes
   WHERE lookup_type = 'PAYMENT TYPE'
   AND lookup_code = 'M'  
 
  /*Following this, for the manual payments there are no further actions, i.e there is nothing like
   building ,formatting,confirming etc.It just reduces the supplier balance.
   The advantage of manual payments, is that you can create a single manual payment for
    multiple pay-alone invoices or you can pay a supplier who has Hold All Payments enabled. */

    /*QUICK Payments : Quick Payments is a process where you quickly print a payment document
 like check and send it to supplier. Basically when you create a payment,then only you
 specify which invoice you are paying. The advantage is that you can select an invoice
 regardless of the due date or payment terms.
 However in this case, after you create a payment you will format and print the payment,but
 there is no build stage.*/

   select payment_type_flag, payment_method_lookup_code,check_id,check_number
   from ap_checks_all
   where check_number= '1000010'

   -- put the above check id here to get payment/invoice information.
   select invoice_payment_id,invoice_payment_type, accounting_event_id, cash_posted_flag,check_id,
   invoice_id,amount,period_name ,accounting_date
   from ap_invoice_payments_all
   where check_id = 10500  

   SELECT *
   FROM ap_lookup_codes
   WHERE lookup_type = 'PAYMENT TYPE'
   AND lookup_code = 'Q'  
 

   -- GL TRANSFER :
   /*Now we need to transfer these invoices and payments transactions to the General Ledger.
   Typically this happens in stages. The steps involved are
             "Payables Transfer to GL",
      "Journal Import" and
      "Posting to General Ledger".
   When we run the "Payables Transfer to GL", the data gets moved into the GL_INTERFACE table,and here
   we can optionally mention to do the Journal Import as well. Hence after the Journal Import is done,we
   can check the data in the following tables.*/
 
   select * from gl_je_headers
 
   select * from gl_je_batches
   where creation_date  = (select max(creation_date) from gl_je_batches)
 
   select max(creation_date) from gl_je_lines
 
   /* Generally while running the Posting Process i.e "Automatic Posting", the program will ask for
   the autopost set id.  For this we go to the form "Autopost Criteria Sets" and create a criteria
   set by providing the priority,source,
   category, balance type and period columns.
   Having created a criteria set, we can then run the conc program (we can also run from the same form)
   by providing this autopost set id */
 
   select *
   from gl_automatic_posting_sets
 
   /* Hence after Posting process is completed we can check the gl_balances table which will contain most
   importantly ,only the summarized information. */
 
   SELECT *
   FROM   gl_balances
   wHERE code_combination_id =4583
   order by last_update_date desc  
 
   /*Use the Payables func to print a check. A payment document should need only
     one document number right?
   --why is that it needs so many document numbers from last used to last available
     numbers.*/
 
   /*
   You need create receipt first and invoice later. If you created invoice and match
   to po the invoice will be on hold as no receipts are created.
   */
 
   /* PREPAYMENTS IN ACCOUNTS PAYABLES :
   There are two kinds of prepayments => Temporary and Permanent.
   Temporary prepayments are those which you apply to an invoice.
   Perf
   The way you deal with the prepayments in AP is that, you first create a prepayment invoice for a
   particular supplier and make a payment for that prepayment invoice. Then whenever you are entering
   an invoice for that supplier ,the system will prompt you saying that there is a prepayment against
   this supplier.

 1)  First create a Prepayment invoice,make sure it is temporary, and provide a settlement date.

 2)  Make a payment for this prepayment invoice by doing this
     Actions => Pay in Full
     (why the prepay invoices needs to paid in full,why not partial?)

 3) Now create a Standard Invoice for the same above supplier. when you tab out of the supplier window,
     the system prompts you saying that, there is a prepayment for this supplier.

 4) Next there are two ways, a prepayment can be applied to the supplier invoice.
     * First you pull up the prepayment invoice and click on the
      Actions=> Apply/Unapply Payments.
        now this will give all the eligible invoices for that supplier and you can apply to one or
   more than one number of invoices.
     * Second,you pull up the Supplier invoice created in the step 3 and choose
      Actions => Apply/Unapply Payments.
      In this case also the screen looks very similar with the exception that you have an
   additional check box "Prepayment On Invoice". If you check this, that what it means is
   that the supplier invoice has included the prepayment amount as well
      in the invoice amount. The only difference in both the ways of application is in the
   creation of accounting distributions.
   (Prepayment on Invoice checkbox :ticking the 'Prepayment on Invoice' checkbox when you
   Apply the prepayment? This will create a new negative distribution line on the invoice
   and reduce the overall invoice distribution total accordingly)
 */
 select  aia.invoice_id,invoice_date,invoice_type_lookup_code, aida.prepay_distribution_id,
    prepay_amount_remaining
 from ap_invoices_all aia, ap_invoice_distributions_all aida
 where  aia.invoice_id = aida.invoice_id
 and    aia.invoice_num like '08-MAR-2007'

  select * from ap_payment_bsets_all

    /* In AP, you cannot create payments without associating them with the invoice. That is ,without
  a supplier invoice which has an open balance,you cannot create payments.
 */

  select * from ap_invoice_prepays_all where last_update_date > sysdate -100
 
   select * from ap_payment_history_all where last_update_date > sysdate -1
 
 /*Payables & Cash Management => If the cash clearing needs to work, then
    you need to give the correct cash clearing account information in the
    bank account as wells as the payables documents level. then it will hit
    the cash clearing account when a payment is account. further when you use
    the cash management you can reconcile the bank statements with the cash
    clearing account.
    */
 
 
  Recurring Invoices :
  --------------------
 
  Generally a supplier sends a invoice and we enter it into our system. However
  sometimes we can also generate a invoice on behalf of supplier. This can be done
  by recurring invoice. A recurring invoice works on the line of recurring journals
  in GL. It works in two steps,
    Recurring Invoice template Definition
  Recurring invoice creation.

 Some of the important things that are needed in the template definition are
   Special calendar => needs to be defined,with months,quarters etc.
   Distribution source => get it from the distribution set or from PO.
   About the calendar : Let us say if there is calendar consisting of 12 periods
   from January to December.
   And if you want first invoice period to be ,say , May. Then the next period
   will be populated as May. Once the invoice has been generated, the next
   period will be Jun. So at any point of time, we can see what will be the
   next recurring invoice period. (The fields next invoice period and the
    next amount indicate are non-editable  fields).

     There are two special amounts and periods, that means, on that period,
   the invoice amount will be that amount.
   
     Once a recurring invoice has been generated, you cannot change any fields
   in the recurring template,other than the account distribution.
 
     Do we need to come to the template everytime and run the recurring invoice
   isn't that cumbersome ??
 
  Payables Credit Memo, Debit Memo :
  ----------------------------------
 
  A credit memo is a document sent by the supplier which decreases the supplier balance.
  It is a negative amount and is applied by matching to an supplier invoice.
 
  A debit memo is a document which you create and send it to the supplier for their
  reference. It is also a negative amount and is applied by matching to an supplier invoice
  and it decreases the supplier balance.
 
 
  Pay group :
     Pay group is a look up code defined in the purchasing application.
 
 
 
 Q & A
 ------
 Receiving Transactions processor should be running.


  /*Payables Invoice Import Process
  _______________________________
 
  The following process goes thru the flow of generating the invoices (along with the underlying table updates)
  until the ultimate GL Posting Process.
 
  Invoices Testing Queries :
 
  -- Set the Environment */
 
     begin
     fnd_client_info.set_org_context(fnd_profile.value('ORG_ID'));
     end;
 
   -- Run the invoice_test.sql to populate the invoices into the ap_invoices_interface table.
 
     select status,source,count(*)
     from ap_invoices_interface
     where source = 'WW-Real Estate-Payments'
     group by source,status
 
   -- Run the concurrent program "Payables Open Interface Import", with the invoice batch name as any name.
     The import program will create a record in the ap_batches_all
 
   -- You can keep checking the query #1 whether the invoices are processed or not in the source table.
 
   -- We can also check in the destination table after setting the env, by running the following query.
 
     select  to_char(creation_date,'DD-MON-YYYY HH24:MI:SS') ,
         count(*)
     from ap_invoices -- (or ap_invoices_all)
     where trunc(creation_date) = trunc(sysdate)
     group by to_char(creation_date,'DD-MON-YYYY HH24:MI:SS')
 
   -- Get one such invoice imported into ap_invoices
 
     select invoice_id,approval_status, posting_status ,wfapproval_status,
         to_char(creation_date,'DD-MON-YYYY HH24:MI:SS') creation_date,
         to_char(last_update_date,'DD-MON-YYYY HH24:MI:SS') last_update_date
     from ap_invoices
     where creation_date = (select max(creation_date) from ap_invoices)
     and rownum < 2
 
   --  The Following programs are scheduled in SJPRF to run for every 10 minutes.
     
       /* "Invoice Validation" Concurrent Program.(APPRVL) (Param: Process all matching lines)
    If the approval_status_lookup_code = 'APPROVED', THEN the status is 'VALIDATED'. if the
     approval_status_lookup_code is 'NEEDS REAPPROVAL', then the status is 'needs revalidation'
    */
         select  to_char(creation_date,'DD-MON-YYYY HH24:MI:SS'), count(*)
         from ap_invoices_v
         where trunc(creation_date) = trunc(sysdate)
         and approval_status_lookup_code = 'APPROVED'
         group by to_char(creation_date,'DD-MON-YYYY HH24:MI:SS')

       select invoice_id,approval_status, posting_status ,wfapproval_status,approval_status_lookup_code
       from ap_invoices_v
       where invoice_id = 5354999
 
   --   Run the "Payables Accounting Process" Concurrent program. (Param:  Validate Accounts : NO).
 
         select to_char(creation_date,'DD-MON-YYYY HH24:MI:SS'),count(*)
         from ap_ae_headers_all where trunc(creation_date) =trunc(sysdate)
         group by to_char(creation_date,'DD-MON-YYYY HH24:MI:SS')
       
         select to_char(creation_date,'DD-MON-YYYY HH24:MI:SS'),count(*)
         from ap_ae_lines_all where trunc(creation_date) =trunc(sysdate)
         group by to_char(creation_date,'DD-MON-YYYY HH24:MI:SS')
 
   /* "Workflow Background Process" for invoice approval. This is already enabled for every 30 sec in SJPRF.
        OR "Invoice Approval Workflow" needs to be run.
   
   --Before approval, the below query should give the import count#  */
 
         select to_char(creation_date,'DD-MON-YYYY HH24:MI:SS'),count(*)
         from ap_invoices_v
      where trunc(creation_date) =trunc(sysdate)
      and   wfapproval_status = 'WFAPPROVED'
         group by to_char(creation_date,'DD-MON-YYYY HH24:MI:SS')
 
   -- After approval process,  the above query should give 0 records.  
     
     /*   "Cisco Payables GL Transfer Post Program" ap_invoice_distributions_all (posted_flag),
          (gl_interface, gl_je_batches, gl_balances.)
    After the feeder systems (i.e AP,AR ) transfer the data to GL, they first go to gl_interface table and then
    from there , they are moved to the gl_je tables. Once these entries are posted, they will update the
    gl_balances table.  
    So this program essentially kicks off
     Payables Transfer to GL
     Journal Import
     Automatic Posting
    Hence it is important we need to have US GL Super User resposibility assigned to ourself
    before we kick off this program.
      */
                select to_char(creation_date,'DD-MON-YYYY HH24:MI:SS') ,count(*)
                from gl_je_headers
                where trunc(creation_date) = trunc(sysdate)                                                  
                group by to_char(creation_date,'DD-MON-YYYY HH24:MI:SS')
 
            select to_char(creation_date,'DD-MON-YYYY HH24:MI:SS') ,count(*)
                from gl_je_lines
                where trunc(creation_date) = trunc(sysdate)                                                  
                group by to_char(creation_date,'DD-MON-YYYY HH24:MI:SS')
     
       select table_name,num_rows from dba_tables where table_name in
       ('AP_AE_LINES_ALL')
 
    /* Once the invoices are imported into the ap_invoices_all , ap_invoice_distributions_all tables from
   ap_invoices_interface and ap_invoice_lines_interface, we can also look at them from the applications
   either in the invoice form or look at all the invoices in
        Invoice=>Invoices=>Open Interface Invoices. */

   /*
   Quick Invoices & Invoices Workbench:
   Quick invoices window will not do much of the validation and do not default the values.
   Also this information will go into the ap_invoices_interface table,after which we can run the
   invoice import program to import them in AP.

   For manually entered invoices,when we validate them, does it do matching and if it does,where is
    the PO information.
 */

--
For invoice matching is the PO really required, just by the supplier id, cant the
system go and find the related PO and match them.  so we found that for the matching
to succeed we really need a PO for the invoice,otherwise it fails.
--
regardless of the po, for each receipt, you generally have one AP invoice.
--
you can receive any amount lesser than the PO line amount, however the over-receipt
tolerance amount pertains to the scenaroi,when u r receiving more than the po line amount.
--
The only way you can enter a quantity invoiced amount in the invoice distribution is
to match it to a po line /shipment.
then the quantity invoiced is defaulted to the value of the po line qnty requested
You could edit that value if you want to and change it.
--
so basically in matching the invoice distributons are matched to the PO lines/distributions
 or receiving distributions based on 2 way or 3 way matching.


--- QUESTIONNAIRE :

1) Is there a tax hiearchy in AP as well ???

 Yes. Just like in AR,here too we define tax code(from tax types) and tax codes
 can be specified at different places like Supplier, site, payables options,
 invoice header, template. And the hierachy of preference can be found in the
 Financial options.
 Howeer I did not find the location tax code in the tax code in the payables. This
 is probably because the company is not taxing ;it is supplier who will have to
 apply the taxes.


2) What is a voucher and document sequence ??
 Since two suppliers can provide you two invoices which might have the same invoice
 number, in which case, invoice number cannot be unique. Hence you have to create
 a voucher number within your system for these two invoices, so that you can
 uniquely identify them.

 Also we can assign a document sequence for each document category with in the
 Oracle applcations system. And so you can for a AP invoice.Simple steps are
   
    There are already predefined document categories like AP invoice, AP credit memo,
       so no need to create anything new
    Create a new sequence with starting number, etc.
    Assign the above sequence to a particular  
        (Application, Category, Set of Books, Start date)
  Ensure that Sequential Numbering profile option is aptly set.

3) What happens in these matching  scenarios ??

   PO , 2 -way  => No confusion here, 2-way matching is performed,
   Receipt, 3-way => No confusion here, 3-way matching is performed.
 
   PO, 3-way => what will happen here, 2-way matching or 3-way matching with receipts
   Receipt, 2-way => what will happen here , 3-way matching or matching with PO's.
 
   Also between, 2 way vs 3 way matching, which one is used in what circumstances
   and what are the advantages of one over the other?   when both of them can be
   used, which is preferred ?  is it like the more receipts for a PO, better 3,4 way matching?

4)What are credit memos and debit memos in Payables ??
  A credit memo is a document sent by the Supplier which you will apply to
  an invoice and which reduces the invoice balance.
 
  A debit memo is a document which you will create ,which will also reduce the
  invoice balance,and send it tto the supplier for verification,approval.
 
5) Should every invoice in Payables be a part of an invoice batch?  
 
 If the profile option "AP: Use Invoice Batch Control" is set to yes, then you can
 create an invoice only after you create a invoice batch.
 If the above profile option is set to No, the  you can create a standalone invoice,
 without being part of a batch.

6) Should every payment be a part of a payment batch?

   No.
   Payments => Entry => Batches ; Payment batches go thru the build,format and confirmation.
   Payments=> Entry => Payments ; If you enter a standalone payments, they are called
        single payments and they are of 3 types (Quick,Manual,Refund).

7)What is the difference between online Matching and offline Matching????

 When you are entering online invoice in Invoice workbench, the only way you
 can enter an invoice quantity (Match Quantity) is by matching it to a PO line,upon
 which the invoice quantity is defaulted from the PO line,which you can change.
 So you cannot manually type in the invoice quantity in the Invoice distribution
 with out matching.

 However if we manually create an invoice line which is identical to a PO line then
 run matching,then the system just matches and validates it successfully.
    what is that so & why there is no invoice qty field in the distribution form

8) What are the steps required to void a check in AP ?    

9) Difference between suppliers and vendors ??
     I believe vendor is a type of supplier. This is bcoz, when you choose supplier type,
  you have a option of vendor there.The different kinds
         of suppliers are government, federal ,Mfg.
  Also Employee is a type of Supplier.
     try to see where you can define supplier types.

10) For manually entered invoices,when we validate them, does it do matching and if it does,where
 is the PO information??
         Yes it does matching and its puts on hold if there is no corresponding matching. In such
   case,you can release the hold manually.

11).When I go to the view accounting from the receiving transaction, i am not able to see the accounting
 entry for the accrual account??
             Firstly ensure that you have accrue on receipt. And then if you do that, then the
    accounting lines are automatically xferred to GL and can be seen
             in gl_interface.

12).In Oracle 11i, there is no centralized payment systems ??
 which means that you just cannot have a
  bank defined in one country and send payments from that bank. You need to define banks in each
   operating unit. So it is understandable bank is tied to an operating unit/ SOB id.

 When we build the payments, it is important that you can only give one type of payment types
  i.e you cannot build corresponding to CHECK and ACH with in a payment batch.

Comments

Popular posts from this blog

Create Accounting for a Payment generates errors 95333 and 95359

Create Accounting for a Payment generates errors 95333 and 95359 Error: 95333: A conversion rate does not exist to convert USD to AUD for the conversion type Corporate and conversion date 20-MAR-09 for line -25. Please use the Daily Rates form in General Ledger to enter a conversion rate for these currencies, conversion date and conversion type. 95359: There is no accounted amount for the subledger journal entry line. Please inform your system administrator or support representative that: The source assigned to the accounting attribute Accounted Amount has no value for extract line number 88547. Please make sure the source assigned to the accounting attribute Accounted Amount has a valid value, or assign a different source to this accounting attribute. Solution: 1. Specify a conversion rate for the currencies and conversion date mentioned in the error message 95333 Navigation under the General Ledger responsibility: Setup > Currencies > Currency Rates Manager > Daily Rates ...

Public API’s for FA Transactions

Public API’s for FA Transactions So far Oracle FA is have all the good things except the lack on reporting.Oracle FA is now offer lot of public API's that can be used to interfacing with third party or Oracle application other modules. Here are some of transaction's API's:   Additions API if you have requirement to add assets directly via PL/SQL then use  FA_ADDITION_PUB.DO_ADDITION. If you have selected the Allow CIP Assets check box on the Book Controls window of a tax book when adding CIP assets using the Additions API, the this API automatically adds those CIP assets to that tax book at the same time that they are added to the corporate book. Adjustments API you can make cost adjustments to your assetsdirectly via PL/SQL using  FA_ADJUSTMENT_PUB.DO_ADJUSTMENT  for any  process adjustment. Detail can be found in appendix H) You can use this API if you have a custom interface that makes it difficult to use with the existing Oracle Assets interfaces for adjusti...

AP Table Relation Oracle Apps

AP Table Relation Oracle Apps ORACLE PAYABLE TABLE RELATION Source Table Dependent Table Condition AP_INVOICE_LINES_ALL AIL ZX_LINES_SUMMARY ZLS AIL.invoice_id = ZLS.trx_id and  ZLS.application_id  = 200 and  ZLS.entity_code  = 'AP_INVOICES' and  ZLS.event_class_code  in ('STANDARD INVOICES', 'PREPAYMENT INVOICES', 'EXPENSE REPORTS') and  AIL.summary_tax_line_id = ZLS.summary_tax_line_id AP_INVOICE_LINES_ALL AIL ZX_LINES ZL AIL.invoice_id = ZL.trx_id and  ZL.application_id  = 200 and  ZL.entity_code  = 'AP_INVOICES' and  ZL.event_class_code  in ('STANDARD INVOICES', 'PREPAYMENT INVOICES', 'EXPENSE REPORTS') and  AIL.line_number = ZL.trx_line_number AP_INVOICE_DISTRIBUTIONS_ALL AID ZX_REC_NREC_DIST ZD AID.invoice_id = ZD.trx_id and  ZD.application_id  = 200 and  ZD.entity_code  = 'AP_INVOICES' and  ZD.event_class_code  in ('STANDARD INVOICES', 'PREPAYMENT INVOICES', 'EXPENSE REPORTS') and...