Documente Academic
Documente Profesional
Documente Cultură
1. What is an EO?
a. Map to a database table or other data source
b. Each entity object instance represents a single row
c. Contains attributes representing database columns
d. Fundamental BC4J object through which all inserts/updates/deletes
interact with the database
e. Central point for business logic and validation related to a table
f. Encapsulates attribute-level and entity-level validation logic
g. Can contain custom business methods
2. What is a VO?
a. Represent a query result
b. Are used for joining, filtering, projecting, and sorting your business data
c. Can be based on any number of entity objects
d. Can also be constructed from a SQL statement
4. What is a Controller?
Controller is the java file and can be associated to a complete OAF page or to
a specific region.
There are several tasks you will do routinely in your code.
? Handle button press and other events
? Automatic queries
7. What is extension?
Extension is when you take an already existing component ex an OAF page
or a region and then add some more functionality to it without disturbing the
original functionality.
8. What is personalization?
Oracle Apps Framework has an OA Personalization Framework associated
with it so that you can personalize any OAF page in an Oracle E-business
Suite application without changing the basic or underlying code of that OA
Framework page, Oracle Application Framework makes it very easy to
personalize the appearance of the page or even the personalization of data
displayed on to an OA Framework page.
2. Localization Level
3. Site Level
4. Organization Level
5. Responsibility Level
6. Admin-Seeded User Level
7. Portlet Level
8. User Level
1) What is BC4J?
Entity Object - EO encapsulates the business logic and rules. EOs are used
for Inserting, Updating and Deleting data from the database table. E0 is also
used for validating the records across the applications.
View Object - View object encapsulates the database query. It is used for
selecting data. It provides iteration over a query result set. VOs are primarily
based on EOs. It can be used on multiple EOs if the UI is for update.
2) What is an EO?
EO encapsulates the business logic and rules.EOs are used for Inserting,
Updating and Deleting data. This is used for validating across the
applications. We can also link to other EOs and create a Association object.
3) What is an VO?
View object encapsulates the database query. It is used for selecting data. It
provides iteration over a query result set.VOs are primarily based on Eos. It
can be used on multiple EOs if the UI is for update. It provides a single point
of contact for getting and setting entity object values. It can be linked
together to form View Links.
4) What is an AO?
An association object is created where we link EOs. For example take the
search page where we link the same EO to form a association between the
manager and employee. Every employee should have a manager associated.
But if it President then no there is no manager associated. This is a perfect
example to understand the AO.
5) What is an VL?
A view link is an active link between view links. A view link can be created by
providing the source and destination views and source and destination
attributes. There are two modes of View link operation that can be
performed. A document and Master/Detail operation.
10) What is the difference between inline lov and external lov.
Inline lov is a lov which is used only for that particular page for which it was
created and cannot be used by any other page.
External lov is a common lov which can be used by any page. It is a common
component for any page to use it. It can be used by giving the full path of
the lov in the properties section External LOV of the item.
1) what is a Javabean?
JavaBeans is an object-oriented programming interface that lets you build reuseable applications or program building blocks called components that can
be deployed in a network on any major operating system platform.
4) what is MDS?
MDS is MetaData Service. When a web page is broken into small units like
buttons, fields etc they are stored in a database. These are not stored as
binary files but as data in tables. The data are present in JDR tables. MDS
provides service to store & return page definitions. MDS collects those
definitions in components/fields in a meaningful manner to build a page.
5) What is XML?
XML is a markup language for documents containing structured information.
Structured information contains both content (words, pictures, etc.) and
some indication of what role that content plays (for example, content in a
section heading has a different meaning from content in a footnote, which
means something different than content in a figure caption or content in a
database table, etc.).
7) What is Personalization?
Personalization enables you to declaratively tailor the UI look-and-feel, layout
or visibility of page content to suit a business need or a user preference.
Using Personalization we can:
9) What is rootAM?
The application module which is associated with the top-level page region
(the pageLayout region) is root application module.
The root AM is loaded first and after that the MDS Substitutions are parsed.
Hence ROOT AM gets loaded even before the time the substitutions
definition from MDS layer get worked out.
http://posamoracleapps.blogspot.com/2012/02/oaf-interview-questions.html
More and more jobs demand OA Framework skillsets these days.
In fact it is safe to say that you would need OA Framework development
experience to have an edge as an Oracle Applications Consultant.
Indeed OA Framework will become a thing of past with Fusion, however
OA Framework will be used for next at least 5 to maximum 10 years
The concepts of OAF, specifically BC4J, can be carried forward to ADF.
Question 3
Tell me the practical steps for extension of a view object, starting from
$JAVA_TOP to jDeveloper
Question 4
Please tell me the scenario in which extension to View Object is not upgrade
safe?
Question 5
In Oracle Forms, we have WHEN-VALIDATE-RECORD? What will be the
equivalent to that in OAFramework?
Question 6
How do you disable all the OA Framework personalizations in eBusiness Suite
Question 7
How do you disable all the OA Framework extensions in eBusiness Suite
Question 8
You are working on two projects, both involve OA Framework.
One instance is on 11.5.10-Rollup2
Other instance is on R12-Rollup4
Can you setup up development environment for both these instances on your
PC/Laptop? If yes, then please explain how.
Question 9
How do you enable a pop-up screen in OA Framework [without using
javaScript]?
Question 10
Can you add new columns to an Advanced Table region/section using
personalization?
Question 11
Tell me one scenario in which you would have to extend Application Module?
Question 12
Can you extend every possible Application Module?
Question 13
A slightly advanced question will beWhy cant Root AM be extended?
Question 14
How would you know whether the AM that you are trying to extend is the
RootAM?
Question 15
Which two types of extension are the most common ?
Question 16
Why do you think multiple AMs are required in a Transaction/Transactions?
Give me an example where this is applicable.
Question 17
On any given OA Framework page, what is the sequence in which these
methods will fire in a Controller?
processFormData
processRequest
processFormRequest
Question 18
A user clicks on a Submit button on a page. The fields on this page are
attached to View Object attributes, which in turn are attached to Entity
Object attributes. An exception is raised from validation EO due to data
validation errors.
Tell me, which methods in controller will be fired when a Submit button is
clicked on that page [assuming validations in EO throw an exception]
Question 18
What are the steps to embed a custom region into a standard OA Framework
page?
Question 19
You have two OA Framework pages, page A and page B. Depending upon the
value of a department selected in PageA, you wish to restrict the LOV of
Approvers in page B.
How will you do this? Why would would not prefer to extend the viewObject
of LOV?
Question 20
What are different methodologies that you can consider to default value into
a field?
Question 21
What are different mechanisms of debugging in OA Framework.
Question 22
From one controller, I wish to execute the code in other controller. Is it
possible, and if yes, then how?
Question 23
I wish to know the SQL statement of a View Object being used by a page.
What is the quickest way to find out?
Question 24
How would you deploy the BC4J extensions to the server?
Question 25
I have extended the View Object and now I wish to locally test that extension
in jDeveloper? Is that possible without loading the jpx file into the database?
Question 26
When you run SQL Trace for an OA Framework session[using diagnostics],
why are multiple *.trc files created on the database server?
Question 27
How do you load XML page developed using jDeveloper?
Question 28
Tell me two different methods you can use to get the XML Files of standard
OA Framework pages.
Question 29
Tell me two different methods you can use to get the XML definitions for
standard OA Framework pages?
Question 30
Please explain the different types of tasks you can do using Functional
Administrator responsibility
Question 31
Lets say a PageA has been personalized in Development and UAT
environments. Is it possible to merge the personalizations done to same
page in two different environments, using Functional Administrator?
Question 32
What is the sequence of Personalizations override?
Responsibility Level
Site Level
Function Level
Organization Level
User Level
Question 33
Where is dbc file located on the server? Is dbc file used by jDeveloper at
RunTime or DesignTime?
Question 34
By setting profile option Disable Self Service Person%, not only the
personalization, but also
the OA Framework extensions get disabled. Please explain why?
Question 35
How do you create User Level Personalizations?
Please explain the steps
Question 36
Off the following levels in Personalizations, i.e. Responsibility Level, Site Level
and Function level, which level has highest and least priority?
They are the VVOs used in validation of attributes, they are the BC4J
components and have their AM ie VAM Validation Application Module
What is the version of Jdeveloper to be used in 11i or R12?
For 11i, Jdeveloper 9i will be used and for R12 Jdeveloper 10g will be used.
What is a Database Connectivity File?
It is a .dbc file which is specified in the project properties. The location of
this file on the server is $FND_TOP/secure
What is a View Object?
It is a BC4J(Business Component for Java) object which encapsulates the
query results. View objects will support the display of the content to user in
the Page.
How do you create a view object?
View objects can be created in the Business components package, can be
based on entity objects or an sql query. View objects based on sql query are
read only view objects
What is an entity object?
Entity object is created based on a database table, it is responsible for
insertion/updation/validation of the table data. They are stored in the
oracle.apps.<prod>.<application>.schema.server package directory
What is an Application Module(AM)?
Application module holds the related objects pertaining to an application
ie. View objects, Entity Objects etc. The application module helps in getting
the required database connection, maintains the page session or transaction
context
What is the object passed to every page request?
OAPageContext object is passed to every request, using this object the
controller initializes the application module object and will call the required
methods.
Where is the view object(VO) initialization or query filtering done?
It is done with view object implementation class Ex. EmpVOImpl.java
What is the property to set for an AM so that the transaction state is
maintained across pages?
RETENTION_LEVEL property is set to value MANAGE_STATE for an AM.
stored as binary files but as data in tables. The data are present in JDR
tables. MDS provides service to store & return page definitions. MDS
collects those definitions in components/fields in a meaningful manner
to build a page.
15) What is XML?
XML is a markup language for documents containing structured
information.
Structured information contains both content (words, pictures, etc.)
and some indication of what role that content plays (for example,
content in a section heading has a different meaning from content in a
footnote, which means something different than content in a figure
caption or content in a database table, etc.).
16) What is the difference between customization and extension?
Customization is under direct user control. The user explicitly selects
between certain options. Some customization examples include:
Altering the functionality of an application
Altering existing UI
Altering existing business logic
Extension is about extending the functionality of an application beyond
what can be done through personalization. Some extensibility
examples include:
Add new functional flows
Extend or override existing business logic
New application/module
New page
New attribute
Extend/Override defaults & validations
17) What is Personalization?
Personalization enables you to declaratively tailor the UI look-and-feel,
layout or visibility of page content to suit a business need or a user
preference. Some personalization examples include:
Tailor the order in which table columns are displayed.
Tailor a query result.
Tailor the color scheme of the UI.
Folder Forms
Forms Personalization
Oracle Application Framework (OAF)
20) What is rootAM?
The application module which is associated with the top-level page
region (the pageLayout region) is root application module.
Beginners
1. What is BC4J and what are all the components of BC4J?
Ans:
2) What is an EO?
Ans: EO encapsulates the business logic and rules.EOs are used for
Inserting,Updating and Deleting data. This is used for validating across the
applications. We can also link to other EOs and create a Association object.
2. What is an VO?
Ans; View object encapsulates the database query. It is used for selecting
data. It provides iteration over a query result set.VOs are primarily based on
Eos. It can be used on multiple EOs if the UI is for update. It provides a
single point of contact for getting and setting entity object values. It can be
linked together to form View Links.
3. What is an AO?
Ans: An association object is created where we link EOs. For example take
the search page where we link the same EO to form a association between
the manager and employee. Every employee should have a manager
associated. But if it President then no there is no manager associated. This is
a perfect example to understand the AO.
4. What is an VL?
Ans: A view link is an active link between view links. A view link can be
created by providing the source and destination views and source and
destination attributes. There are two modes of View link operation that can
be performed. A document and Master/Detail operation.
5. What is UIX?
Ans: UIX is an extensible, J2EE-based framework for building web
applications. It is based on the Model-View-Controller (MVC) design pattern,
which provides the foundation for building scalable enterprise web
applications.
6. what is MVC Architecture?
Ans: MVC Architecture is a Model View Controller Architecture. The controller
responds to user actions and directs application flow. The model
encapsulates underlying data and business logic of the application. The view
formats and presents data from a model to the user.
7. which is the MVC layer VO located?
Ans: O is located in the View Layer which is responsible for presenting the
data to the user.
8. Which package should include EO and AO.
Ans: The EO and AO will be present in the schema.server package.
what is a Javabean?
what is MDS?
Ans: MDS is MetaData Service. When a web page is broken into small units
like buttons,fields etc they are stored in a database. These are not stored as
binary files but as data in tables. The data are present in JDR tables. MDS
provides service to store & return page definitions. MDS collects those
definitions in components/fields in a meaningful manner to build a page.
14.
What is XML?
Ans: Customization is under direct user control. The user explicitly selects
between certain options. Some customization examples include:
Altering the functionality of an application
Altering existing UI
Altering existing business logic
Extension is about extending the functionality of an application beyond what
can be done through personalization. Some extensibility examples include:
Add new functional flows
Extend or override existing business logic
New application/module
New page
New attribute
Extend/Override defaults & validations
16.
What is Personalization?
21) What are the tools you had used for decompiling java class?
Ans:
Jad is one of the tool for decompiling the java class.
EXPERT
1. What will setmaxFetchSize(0) will do?
Ans: setmaxFetchSize just determines how much data to be sent at a time.
2. Can we use dynamically created VO in OAF?What is the pros and cons?
Ans: Want to answer this section? use the comment section.
3. What is advanced table in table?
Ans: Want to answer this section? use the comment section.
4. What is a HGrid?
Ans: A HGrid, otherwise known as a hierarchy grid, allows users to browse
through complex sets of hierarchical data.
5. Tell me the OAF components required for a simple search page?
Ans: VO,AM,Page
6. What is a switcher in oAF and when it is used?
Ans: A switcher is a control, that allows the selective display of
information.For example if you want to display a image for update enabled
and update disabled you can use switcher.
7. What are all the methods in CO?
Ans: processForRequest
processRequest
8. When a page renders which method in CO fires?
Ans: processRequest
9. How do you handle back button navigation in OAF based application?
Ans: Want to answer this section? use the comment section.
10.
Ans: EO.
11.
Ans: When you want to display buttons on top and bottom of the page then
you create a region as pageButtonbar and create buttons within this region.
14.
Ans: Create a new item with style as link and give its destination uri property
which is the url where you want to navigate to.
15.
Ans: PageLayoutRN
16.
Ans: Not necessary. If you are creating a record then we need a EO.
20.
21.
What will happen when you set DisableClientSideValidation
property to True?
Ans: If you set the property to True it shows that there will no validation that
will occur on the web tier as part of the form submit.
22.
What is SPEL?
Ans: SPEL is used in places where you want to show or hide an item
programatically.
24.
What is PPR?
Ans: PPR is Partial Page rendering. Which means that only a particular part of
the page is refreshed and not the entire page.
25.
39.
Ans: pageContext.forwardImmediately("OA.jsp?
page=/xxch/oracle/apps/fnd/test/webui/DetailsPG&fname="+fname.
Here fname is the variable we are passing to the DetailsPG.
15.
What is serializable?
Ans: pageContext.getOANLSServcies().formatCurrency(num,"USD");
28.
Question 1
You wish to hide a bean/field programmatically, where will you do that?
a. In controller
b. In Application Module
c. In Entity Object
d. In View Object
Answer In controller[Although SPEL with limited usage can also be
considered]
Question 2
Within which method of Controller will you hide that bean/field/button/region
programmatically?
1.
processRequest
2.
processFormRequest
3.
Both processRequest and processFormRequest
Answer is 1. - processRequest
Question 4
Please tell me the scenario in which extension to View Object is not upgrade
safe?
Answer- If the original view object was created in expert mode, then you will
have to copy the Original VO Query and then you will paste that SQL
Stmt/Query into the extended View Object.
Now, if Oracle were to change the original SQL Statement [against original
VO], then those changes will not be reflected in extended View Object.
Is there any solution?
Well, yes, depends on what you wish to achieve via personalization.
If you simply wish to alter the where clause dynamically, then you might as
well do that by extending the controller.
Note:- When extending the CO, we are assuming that at least the selected
table aliases from the Original SQL Statement will not be removed by
Oracle's patches.
Question 5
In Oracle Forms, we have WHEN-VALIDATE-RECORD? What will be the
equivalent to that in OAFramework?
Answer - Use a method named validateEntity() within the Entity Object.
Question 6
How do you disable all the OA Framework personalizations in eBusiness Suite
Answer- All the personalizations done to the system can be disabled by
simply setting a profile option to Yes at site level.
Name of this profile option is something like Disable%Self%Service%Personal
%
Note:- You can de-activate personalizations against individual pages
selectively, by clicking on button "Manage Personalizations". You may need
to give yourself access to responsibility named "Functional Administrator", so
that you can disable personalizations selectively.
Question 7
How do you disable all the OA Framework extensions in eBusiness Suite
Answer - The answer to this question is same as that for Question 6.
Extensions are stored in the MDS Layer. Hence if you disble all
personalizations, then all the OA Framework extensions will also be removed
temporarily, while that profile remains set to Yes.
This is very handy in case you wish to bring your product back to Vanilla
state.
Question 8
You are working on two projects, both involve OA Framework.
One instance is on 11.5.10-Rollup2
Other instance is on R12-Rollup4
Can you setup up development environment for both these instances on your
PC/Laptop? If yes, then please explain how.
Answer
Question 9
How do you enable a pop-up screen in OA Framework [without using
javaScript]?
Answer
Question 10
Can you add new columns to an Advanced Table region/section using
personalization?
Answer We can add columns using personalization.
Question 11
Tell me one scenario in which you would have to extend Application Module?
Answer
Question 12
Can you extend every possible Application Module?
Answer
Question 13
A slightly advanced question will beWhy cant Root AM be extended?
Answer
Question 14
How would you know whether the AM that you are trying to extend is the
RootAM?
Answer
Question 15
Which two types of extension are the most common ?
Answer
Question 16
Why do you think multiple AMs are required in a Transaction/Transactions?
Give me an example where this is applicable.
Answer
Question 17
On any given OA Framework page, what is the sequence in which these
methods will fire in a Controller?
processFormData
processRequest
processFormRequest
Answer
Question 18
A user clicks on a Submit button on a page. The fields on this page are
attached to View Object attributes, which in turn are attached to Entity
Object attributes. An exception is raised from validation EO due to data
validation errors.
Tell me, which methods in controller will be fired when a Submit button is
clicked on that page [assuming validations in EO throw an exception]
Answer
Question 18
What are the steps to embed a custom region into a standard OA Framework
page?
Answer
Question 19
You have two OA Framework pages, page A and page B. Depending upon the
value of a department selected in PageA, you wish to restrict the LOV of
Approvers in page B.
How will you do this? Why would would not prefer to extend the viewObject
of LOV?
Answer
Question 20
What are different methodologies that you can consider to default value into
a field?
Answer
Question 21
What are different mechanisms of debugging in OA Framework.
Answer
Question 22
From one controller, I wish to execute the code in other controller. Is it
possible, and if yes, then how?
Answer
Question 23
I wish to know the SQL statement of a View Object being used by a page.
What is the quickest way to find out?
Answer
Question 24
How would you deploy the BC4J extensions to the server?
Answer
Question 25
I have extended the View Object and now I wish to locally test that extension
in jDeveloper? Is that possible without loading the jpx file into the database?
Answer
Question 26
When you run SQL Trace for an OA Framework session[using diagnostics],
why are multiple *.trc files created on the database server?
Answer
Question 27
How do you load XML page developed using jDeveloper?
Answer
Question 28
Tell me two different methods you can use to get the XML Files of standard
OA Framework pages.
Answer
Question 29
Tell me two different methods you can use to get the XML definitions for
standard OA Framework pages?
Answer
Question 30
Please explain the different types of tasks you can do using Functional
Administrator responsibility
Answer
Question 31
Lets say a PageA has been personalized in Development and UAT
environments. Is it possible to merge the personalizations done to same
page in two different environments, using Functional Administrator?
Answer
Question 32
What is the sequence of Personalizations override?
Responsibility Level
Site Level
Function Level
Organization Level
User Level
Answer
Question 33
Where is dbc file located on the server? Is dbc file used by jDeveloper at
RunTime or DesignTime?
Answer
Question 34
By setting profile option Disable Self Service Person%, not only the
personalization, but also
the OA Framework extensions get disabled. Please explain why?
Answer
Question 35
How do you create User Level Personalizations?
Please explain the steps
Answer
Question 36
Off the following levels in Personalizations, i.e. Responsibility Level, Site Level
and Function level, which level has highest and least priority?
Answer
Question 37
How to set responsibility context in OAF like fnd_global.APPS_INITIALIZE is
used in database.
Answer: Achived the results of switching the responsibility context by using
pageContext.changeResponsibility
Question 38
Which responsibility do you need to extract Self Service Personalizations?
Answer:Functional Administrator
Question 39
How will you open a bc4j package in jdeveloper?
Answer Oracle ships a file named server.xml with each bc4j package. You
will need to ftp that file alongside other bc4j objects(VOs, EOs, AM, Classes
etc).
Opening the server.xml will load the complete package starting from
AM(application module). This is a mandatory step when building Extensions
to framework.
Question40
In OA Framework Self-Service screen, you wish to disable a tab. How will you
do it?
Answer: Generally speaking, the tabs on a OA Framework page are nothing
but the SubMenus. By entering menu exclusion against the responsibility,
you can remove the tab from self service page.
Question41
In self service, you wish to change the background color and the foreground
text of the OA Framework screens to meet your corporate standards. How
will you do it?
Answer You will need to do the below steps
a.Go to Mid Tier, and open $OA_HTML/cabo/styles/custom.xss
bEnter below text( change colours as needed)
<style name="DarkBackground">
<property name="background-color">#000066</property>
</style>
<style name="TextForeground">
<property name="color">#0000FF</property>
</style>
c cd $OA_HTML/cabo/styles/cache
dTake a backup of all the css files.
eDelete all the files of following pattern oracle-desktop*.css
The idea here is to delete the cache. Next time when you logon to Oracle
Apps Self Service, the Framework will rebuild the css file if found missing for
your browser.
Question 42
Can you extend and substitue a root AM ( Application Module) in OA
Framework using JDeveloper.
Answer: You can extend the AM in jDeveloper, but it doesnt work( at least it
didnt work in 11.5.9). I am hopeful that Oracle will deliver a solution to this
in the future.
Question43
How will you add a new column to a List Of Values ( LOV ) in Oracle
Question 44
In Oracle OA Framework, is the MDS page/document definition stored in
database or in the file system?
Answer The MDS document details are loaded into database, in the
following sets of tables.
JDR_ATTRIBUTES
JDR_ATTRIBUTES_TRANS
JDR_COMPONENTS
JDR_PATHS
The Document is loaded via XMLImporter, as detailed in XMLImporter Article
Question 45
How does substitution work in OA Framework?
What are the benefits of using Substitution in OA Framework?
Answer Based on the user that has logged into OA Framework, MDS defines
the context of the logged in user. Based upon this logged in context, all
applicable personalization are applied by MDS. Given that substitutions are
loaded as site level personalizations, MDS applies the substituted BC4J
objects along with the personalizations. The above listed steps occur as soon
as Root Application module has been loaded.
The benefit of using Substitution is to extend the OA Framework without
customization of the underlying code. This is of great help during Upgrades.
Entity Objects and Validation Objects can be substituted. I think Root AMs
cant be substituted given that substitution kicks off after Root AM gets
loaded.
Question 46
In OA Framework, once your application has been extended by substitutions,
is it possible to revert back to remove those substitutions?