Friday, September 28, 2007

Multi Org

MULTI ORG

Over View Of Multi Org

Use a single installation of any Oracle Applications product to support any number of organizations, even if those organizations use different sets of books.

(Or)

MultiOrg or Multiple Organizations Architecture allows multiple operating units and their relationships to be defined within a single installation of oracle Applications. This keeps each operating unit's transaction data separate and secure.

(Or)

It determines the relationships among various organizations within an enterprise. It dictates the transaction flow through different organization and how these organizations interact with each other.

Multi Org Structure

Based on the business needs of the enterprise and the inbuilt Org-structure in the applications the different Hierarchy-levels are defined.

The levels are - Business Groups, Set of Books, Legal Entities, Operating Units and Inventory Organizations.Other definitions include Balancing Entity, Process Organization, Item Organization, HR Organization, and Organization for Oracle Projects and Oracle Assets.

It also determines the access level of each oracle application module.

The Hierarchy Of Multi_Org Can depicted as follows.

Business Group

|

Set Of Books

|

Legal Entity

|

Operating Unit

|

Inventory Organization

|

Sub Inventory

|

Stock Location

|

Items

Let me explain each of the components in Multi_Org Structure.

Business Group

It represents the highest level in Organization Structure–a consolidated Enterprise.

The application secures human resource information by business group.

The HR Organization is defined and attached to Business Group. That is, when you request for a list of employees, you see all employees assigned to the business group of which your organization is a part.

Set of Books

It determines the Chart of Accounts,Currency and Calendar that would be used by the financial reporting entity.

General Ledger is considered as heart of Oracle application modules and secures information by set of books.

The Set of books defined are attached to each organization and responsibility that you define in the application to establish relationship for updating transactions.

Legal Entity

It represents a legal company for which you prepare fiscal and tax reports.

A Business Group can have one or more Legal Entities.

The Set of Books that you define for the Financial Reporting Entity is assigned to a Legal Entity.

The multiple reporting currency features in application allows you to record and maintain accounting records in more than one functional currency by creating reporting set of books in addition to primary set of books.

Oracle Applications such as General Ledger, Oracle Inventory, OPM Inventory, OPM Financials and Oracle Assets Operate at Legal Entity Level. Each user can see information of all the organizations within a Legal entity.

The application provides for restricting access to inventory user by organization.

Balancing Entity

It represents the accounting entity for which you prepare financial statements.

This is a segment in Accounting Flex field structure at which all accounting entries must balance.

A legal entity can have one or more Balancing entities.

Flex field Value security rules can be used to restrict data entry of balancing segment by operating unit.

Operating Unit

It represents a division or department in an enterprise.

It is associated to Set of Books and Legal Entity.

A Legal entity can have one or more Operating Units.

It is referred as a ‘Company’ in OPM applications.

Oracle Applications such as Order Management, Purchasing, Payables, Receivables and Cash Management secure information by Operating Unit. Each user can see information only for their operating Units.

Organization

It represents a Manufacturing Plant or Parent organization for a group of warehouses. The Item Master organization is also defined at this level.

It is referred as Process Organization in OPM applications.

It is referred as Master Organization in India localization set-ups – a level at which excise records are maintained.

All Organizations are associated to Set of Books, Legal Entity and Operating Unit.

Inventory Organization

It represents a warehouse, a distribution center, a Sale office and any other organization for which you track inventory transactions and balances.

It is associated to Set of books, Legal entity and Operating Unit.

The parent organization/process organization under which it is created is also assigned.

The Process enabled flag determines whether it is OPM Warehouse or a Discrete warehouse.

You also specify the Item Master organization from which it can derive item information.

In India Localization set-ups, the Master organization to which this warehouse is attached is also defined for consolidation of Excise records.

You have to choose an organization classified as inventory organization to run application like Oracle Inventory and Purchase receiving functions.

Organizations in number

(In most of the Implementations)

Business Group - 1

Legal Entity - 1

Operating Units - 2-3

Organizations - 25-50

Inventory Organizations - 300-500

Technical Aspects:

Multi_Org Tables:

In Oracle Applications we will find some of the tables with suffix ‘_ALL’.

These are nothing but multi_org tables,which are having multiple organizations data. There will be a common column Org_Id.System will insert Org_id value into this column internally from the profile called MO:OPERATING_UNIT.

Multi_Org Views:

For every Multi_Org table there will be a multi_org view without ‘_ALL’ in the view name. This multi_org view will be created based on the multi_org table including where clause ‘where org_id=fnd_profile.value ('ORG_ID')’. Its one of the RDBMS variable containing user org_id value. Whenever user connects to the database system will find out user org_id value through profile and inserts into the variable.

Q:How will you find out that an organization is Multi_Org enabled or not?

Ans: Select multi_org_flag from fnd_product_groups

Y -à Enabled

N -à Not Enabled/Setups Missed

Important Tables in each of the levels in Multi_org hierarchy:

LEVEL

TABLE NAME

COLUMN NAME

Business Group

HRFV_BUSINESS_GROUPS

BUSINESS_GROUP_NAME

Set of books

GL_SETS_OF_BOOKS

SET_OF_BOOKS_ID

Legal Entity

HR_LEGAL_ENTITIES

NAME

Operating Unit

HR_OPERATING_UNITS

ORGANIZATION_ID,NAME

Inv. Org.

ORG_ORGANIZATION_DEFINTIONS

ORGANIZATION_ID,ORGANIZATION_NAME

Sub Inventory

MTL_SECONDARY_INVENTORIES

SECONDARY_INVENTORY_NAME

Stock Location

MTL_ITEM_LOCATIONS

SUBINVENTORY_CODE,ORGANIZATION_ID

Items

MTL_SYSTEM_ITEMS_B

INVENTORY_ITEM_ID,OR GANIZATION_ID

NOTE :

A. If we use Multiorg Table we will get all the Organizations Data

B. If we use Multiorg View we will get the data which is related to User

Organization.

C.While Developing or Customizing the RICE Components in Oracle Apps

we are suppose to use the Multiorg Views not Multiorg Table.

Tuesday, September 25, 2007

SQL Coding Standards

This is Vijay Bhaskar Reddy, Working as a Oracle Apps Sr. Technical Consultant. I want to share my experience with all of you through this blog(www.smartoracle.blogspot.com). If you are having any queries feel free to mail me at reddyvijayk@gmail.com

SQL Coding Standards

  1. Standard keywords, standard or custom package/function names, Table alias, operators are in upper case (e.g. SELECT, DBMS_OUTPUT etc.)
  2. Column names, column alias, table names, view names are in lower case.
  3. SQL statements are indented/aligned as per coding standards doc.(e.g given below) Each ‘Clause’ of SQL statement starts in a new line.
    e.g.
    SELECT RCT.trx_number invoice_number
    ,RCT.trx_date invoice_date
    ,SUM(APS.amount_due_original) invoice_amount
    .........
    FROM ra_customer_trx RCT
    ,ar_payment_schedules APS
    WHERE RCT.customer_trx_id = APS.customer_trx_id
    AND APS.class = ‘INV’
    AND RCT.completed_flag = ‘Y’
    AND RCT.customer_trx_id IN (
    SELECT DISTINCT ARA.customer_trx_id
    FROM ar_receivable_applications ARA
    WHERE apply_date BETWEEN ADD_MONTHS(SYSDATE,-1) AND SYSDATE
    )
    GROUP BY RCT.trx_number
    ,RCT.trx_date
    ORDER BY RCT.trx_number;
  4. Only one column/expression, table or selectivity condition appears on one line.
  5. Comma separating the columns, tables or parameters comes at beginning of lines, not at end.
  6. SELECT clause of sub-query starts on a new line.
  7. No more than 3 parameters of a function (standard or custom) per line.
  8. If parameter is an expression or nested function, then each expression or nested function appears on new lines.
  9. Only one join condition appears in one line.
  10. Keywords: AND or OR appears at the beginning of line (and not at the end).
  11. The column names are not unnecessarily abbreviated.
  12. Column name are inter-connected using ‘_’ (e.g. error_code instead of errorcode)
  13. Each table (except for dual) has a table alias.
  14. The table alias is formed using the first characters of ‘parts’ of table name.

Monday, September 24, 2007

Further Person Information not Displaying on People | Enter And Maintain Form

Oracle Human Resources - Version: 11.5.10
Issue with Perwshrg.fmb , further person information DDF

Problem:
further person information DFF modifications means display different information are not displaying under the Employment Tab of the People Form.This is restricted functionality.

Solution :
Further person Information flexfield is not a Descriptive Flexifield it's a Developer Descriptive Flexifield. This is a restricted functionality.

Developer Descriptive flexfields are reserved for Development & should not be modified.You can see this flexfield information for 'US' legislation's , in PUI on person form, inthe 'Empolyment' tab,All fields with in this tab belongs to this flexifield.

By
Srinivas Ramineni
Oracle APPS DBA

Purging Related to SYS ADMIN & WORKFLOW

This document describes archiving across applications, how to submit the purge processes, purging criteria for records, what information does and does not get purged, the tables information is purged from and how to restore archived information.

System Administration

Archiving Audit Data:

Auditing is the main feature that produces high impact on Applications But it is a very useful tool use it with proper planning.

Disable auditing using the “Disable – Prepare for Archive” and running the Audit Trail Update Tables report.

Archiving it.

Set the Archive group to Disable Purge Table and running the Audit Trail Update tables report.

Purge Concurrent Request and/or Manager Data:

Use this program to delete:

1. Request log files, concurrent manager log files, ad report output files from your product directories maintained by the operating system

2. Records (rows) from Application Object Library database tables that contain history information about concurrent requests and concurrent manager processes.

Use this program to compute performance statistics for each of the concurrent programs, if the Concurrent: Collect Request Statistics profile option is set to “Yes”.

Purge Signon Audit Data:

Use this program to purge Sign-On Audit information created before a specified date.

The following data is deleted:

1. Data for who signs on and for how long

2. Data for who is selecting what responsibility and when they do it

3. Data for who uses which forms in an application and when

Purge Obsolete Generic File Manager Data:

To purge uploaded files form the Generic File Manager, run the concurrent program, Purge Obsolete Generic File Manager Data.

This concurrent program should also be used to periodically delete obsolete data. It is recommended that you schedule this program to run every day or so, using the default parameter values.

Workflow

To purge the workflow runtime tables use the standard concurrent program FNDWFPR ”Purge Obsolete Workflow Runtime Data”.

Instructions

Navigate to the Submit Requests form in Oracle Applications to submit the Purge Obsolete Workflow Runtime Data concurrent program.

You can supply the following parameters for the Purge Obsolete Workflow Runtime Data concurrent program:

Item Type----The item type to purge. Leaving this field blank defaults to purging the runtime data for all item types.

Item Key----The item key to purge. Leaving this field blank defaults to purging the runtime data for all item keys.

Age----Minimum age of data to purge, in days.

Persistence Type----The persistence type to be purged, either ’TEMP’ for Temporary or ’PERM’ for Permanent. The default is ’TEMP’.

Note: If you have implemented Oracle Applications Manager, you can use Oracle Workflow Manager to submit and manage the Purge Obsolete Workflow Runtime Data concurrent program.

By
Srinivas Ramineni
Oracle Apps DBA



Provide Access to "AME Tranaction Types" to a user

Hi,
This is Srinivas Ramineni.

These steps flourishes the way to "How to Provide Access to "AME Tranaction Types" to a user

1) AME restricts access to "AME Transaction Types" using Data Security. To access AME and useit,the user needs to select a transaction type. But the transaction types that the user can select inthe AME Dashboard is restricted by data security.

2) Access to AME transaction types to a user can be setup as follows:
· Login as Administrator
· Select Functional Administrator responsibility
· Select Grants Tab
· Click on Create Grant
· Select "Specific User" as grantee type
· Select the User as grantee key
· Select "AME Transaction Types" as object
· In the next page there will be 3 options for instance type:
1. All rows: This grants access to all AME Transaction Types to the User
2. Instance: This grants access to the AME Transaction Type(1) specified by the following parameters:

FND_APPLICATION_ID => Application ID of the application to which the transaction type belongs
TRANSACTION_TYPE_ID => Unique identifier of the AME Transaction type within application
3. Instance set: This grants access to AME Transaction Types(>=1) specified by the following parameters:
* Use the seeded instance set "AME Transaction Type Instance Set"
* In the next page select FND_APPLICATION_ID as Parameter1 and a wild card search string for TRANSACTION_TYPE_ID as Parameter2.

In the next page, select "AME Calling Applications" as the permission set
· Review and Finish.

NOTE: Please note that it is possible that AME screens fail to appear for the user even after doing the above setup. This can happen if the workflow event system is not properly setup.


If u have any doubts please feel free to contact.

Sunday, September 23, 2007

OPM Profile issue

Hi
Greetings
there is no LOV values like YES or No
there is only options like below

GMF:Use OPM Revenue Account for AR Update
Default : 1
Options :
0 =No
1 = Yes
Description : User OPM Revenue Account.
Recommended Change Levels : Site Level

there is no need to create LOV for profiles .
Default it is "1 " means " yes"
if u want to change it to "NO" use "0"

if u have any doubts feel free to contact.
---Srinivas Ramineni
Oracle APPS DBA

Saturday, September 22, 2007

OPM Profile Option



We are implementing OPM Module. I have one small problem in OPM Profile options.


In Profile Option name GMF: User OPM Revenue Account for AR Update Profile option does not have any list of values.
Actually as per the User guide it should have Yes or No values. Could you please anyone suggest how do we create the LOV for that profile option?


Narendra
Nairobi (Kenya)



Thursday, September 20, 2007

Form Customization through Custom.pll

Hi
This is Rakesh.C . I am an Oracle Apps Technical Consultant working in APL Hyderabad.In this post i am giving some of the facts about Custom.pll in Customizing the Oracle Forms.If you have any queries contact on rakhi.oraapps@gmail.com

CUSTOM.PLL
Oracle Apps contains set of forms, reports and other concurrent programs designed and integrated to meet the needs of specific business functionality.
In order to customize the reports and other concurrent programs we need to download the program from the server and we have to make the customizations.

There are 2 ways to customize the form in the oracle apps.they are
1.download the source (form) from AU_TOP dir, then start customize the form &
2.download the custom.pll from AU_TOP/resource dir, then start customize the form according to specific events


CUSTOMIZING WITH CUSTOM.PLL
The Custom.pll is a Oracle forms pl/sql library which is used for the optimization of Oracle Forms. Through custom.pll we can customize with 2 types of events.They are
1.Generic events and
2. Product specific events

Generic events includes:

When_form_navigate
When_new_form_instance
When_new_block_instance
When_new_record_instance
When_new_item_instance
When_validate_record
Specialn (where n is a number between 1 & 45)
Zoom
Export
Key-Fn (n is between 1 and 8)

Product-specific events includes:
When_logon_changed
When_responsibility_changed
When_password_changed

In order to code the logic through custon.pll we have to mainly observe the following things
1.Formname
2.Blockname and
3.In which event, logic has to be fired

In order to support the various functionality we have to explicitly add the corresponding packages like APPCORE2 etc. APPCORE2 library supports the same functionality as APPCORE package. The main reason for not attaching the APPCORE package to the custom because custom is attached to the APPCORE so it would cause a recursion problem.

Custom.pll contains the following functions and procedures
Function zoom_available return BOOLEAN;
Function style (event_name varchar2) return integer;
Procedure event (event_name varchar2);

Zoom_available function returns the zoom status of the form and block. Style function is used, whenever there is logic for the particular form for particular event and through custom.pll if we used the same event then we can use the style function to change the order of execution for the two same events. And event procedure is used to write the code for various events for the particular form and block based on the customization.

By using this functions and procedures in custom.pll we can easily customize the business login of the forms.

Wednesday, July 18, 2007

Steps to Resolve Concurrent Processing Isuues(ORACLE e-Business Suite)

In this Post i am Explaining about Concurrent Processing issues & How to resolve them.

Introduction:

This Paper describes the day-to-day administrative like performance issues with concurrent processing etc. at Aurobindo Pharma Ltd., a leading pharmaceutical manufacturer, and the solutions to resolve those problem regarding performance of E-Business Suite. you may visit Aurobindo at http://www.aurobindo.com/.

The Goal of this Document is to assist existing Oracle Applications DBA’s and Administrators in identifying the hidden features of Oracle Applications 11i that will affect how they accomplish their day-to-day administrative tasks like managing concurrent processing.

Abstract:

This paper flourishes possible ways to speed up & utilize the processing capacity of Oracle Applications as per it’s maximum extent.

Concurrent Processing:

Before heading into the details of how to manage the concurrent processing, the following are definitions of key terms:

Concurrent Manager: Concurrent manager is a mechanism that runs concurrent programs. A manager operates during the time and days defined by a work shift. A manager can run any concurrent program, or be specialized to run any concurrent program, or be specialized to run only certain kinds of programs.

Concurrent Program: A program that runs concurrently (at the same time) as other programs. Concurrent programs run as background processes, while you continue to work at your terminal.

Note : Oracle’s guidelines for CPU suggested that Estimate the number of users who will use Oracle Applications simultaneously under normal circumstances.

For example We have 500+ end users. This number included multiple open sessions as well browses.

Users opened multiple sessions on their desktops, either to do work through two different applications at the same time, or because performance was so slow that they felt they could get more done with more screens open. As users became increasingly upset about performance, they opened more windows, causing the performance problem to increase because every log-in to Oracle costs about 2.5 MB of memory (2.5*500 users = 1.2GB Approximately).

Note-1: if we lower the number in the Priority field in the Navigate/Concurrent/Requests screen, then the concurrent request’s position in the queue will change and it will run sooner. Sooner, I always caution users, does not mean faster. Changing the priority does not cause the concurrent request to get more resources from the computer when it runs, so if the computer is already overloaded, you will still have performance problems.

Note-2: If we increasing the number of requests, that could run in the concurrent manager didn’t help either. If we plan to use this in Brake sessions with proper planning, it is the best option.

Note-3: if we decreased the size of the SGA. This freed up additional memory for the users to log on, but decreased the amount of memory available for the database, causing it’s own set of performance issues.

Note-4: When we calculated memory requirements, it’s better to assess the impact of Zooms on memory. Zoom- Zooms allow end users to suspend processing in one form, make a side trip to work or view details in another form, then return to the original form and resume processing. If a user zooms, it’s nothing but another login. It’ costs another 2.5 MB memory & it’s not release the memory until the user logoff.

To resolve the performance issues

Actions :

1. asses how many users will use the applications. even if they aren’t doing anything, the memory will be utilized.

2. Many users will log on at least twice.

3. Zooms didn’t release the memory until the user log-off.

4. Count the Concurrent managers themselves as users of memory & CPU.

5. The SGA also requires considerable memory.

Solutions:

1. From Unix, limit the users to logging in two times.

2. Implement a process @ the unix level to automatically kill sessions of users who were idle for more than an hour.

3. Set the correct balance of concurrent managers versus online user performance.

4. Using the scripts, asses the high frequency, high impact, average time & importance of the concurrent request.

6. Give the access on this output data to all users & give the choice to them for scheduling the job.

7. Encourage the users to schedule the requests (means long running & repeatable) to run in the evening.

8. Report the performance problems with forms & reports to the developers.

9. Check the parameters of running open-ended reports.

10. Monitor for locks on tables. Locks affect both online & batch operations.

11. Check for runaway requests mean long running requests, displays CPU clock time increasing & had a unix process id of 1 with no other processes referencing it. In this case, the process may not be cleaned automatically. Use the kill command to terminate the run-away requests.

12. Use the Apps Status Scan scripts & verify the performance issues.

13. Give instructions for users immediately close the database backend, ftp, front end sessions if they are not using.

14. During the Business hours give the preference for Online users & run atleast two processes per manager.

15. Sugests the users to close all sessions with Oracle Applications @ Brake times (lunch time).

16. Working with the above Step, A lot of memory will be released. Use it efficiently with increasing the target processes.

17. Workshifts:

Define workshifts like Business Hours, evening, weekends & End of the Month workshifts.

Business Hours : During the business hours, we had a workshift for 9AM – 6PM.

That minimized the no. of concurrent requests in favor of online users.

Evening Hours: At 6PM, change the workshift to Evening workshift & increase the no. of concurrent requests that could run. As performance improved, we gradually increased the no. of jobs that could run @ once.

Weekend: As per the company holidays, define this workshift & give the primary priority for concurrent requests.

If we properly manage these workshifts, there is no need Maintain any workshifts like Monthend shifts, quarterly shifts etc.

18. Run the purge concurrent requests & manager data programs nightly to delete old files.

19. Remove the older files if the /var/tmp is getting full.

20. Run the Oracle-seeded report User Profile Options periodically to catch users who have left debug or trace options turned on.

21. Monitor file system spaces frequently.

22. Avoid enabling an excessive number of standard or specialized managers.

23. Use specialization rules and work shifts to bind specific jobs to specific time windows.

24. Helps avoid scheduling resource intensive batch requests during peak activity.

25. For jobs, which spawn parallel workers such as Auto Invoice or Payroll, set the sleep time of the Conflict Resolution Manager (CRM) to null (i.e. 10 seconds). The default value is 60 seconds.

26. Transaction Managers:

1. Set the profile “Concurrent:Wait for Available TM” to 1 (second).

2. Set “TP:INV Transaction processing mode” to “On-line processing” for small inventory requests from the UI.

3. Set the sleep time on the transaction managers to a high number (e.g. 10 minutes).

4. Enable tracing if required.

27. Implementation of PCP(parallel concurrent processing) is the another solution to improve performance.
...........................................................................................

--

Srinivas Ramineni

Apps DBA