Populate PK(DBSequence) in three related tables with master detail association
Hi
I use jdeveloper 11.1.1.6.0.
My English isn't very good.
I have 3 tables with master detail association between them and primary key from table A should populate to tables B and finally C .The primary key is a sequence from data base and I set PK attribute in table A as a DBSequence. (table C is the child of table B and table B is the child of table A)
My association is like this: A->B(BAFk1Assoc) and B ->C(CBFk1Assoc) and also I select Composition Association for these two association. And I select ‘Cascade Update Key Attribute’
When I insert row in these three related tables, a negative number create but when I COMMIT the PK populate only to table B not to table C and the exception below raises:
Constraint "C_B_FK1" is violated during post operation "Insert"
ORA-02291: integrity constraint (HR.C_B_FK1) violated - parent key not found.
If I only work with tables A and B, there isn't any problem but if I add table C as the child of B, this exception raises.
Habib
The question is how you create the row for table C. Do you create it as child from table b (using the VO for B and using the link to C)?
In this case the framework should populate the PK of the master row B as FK in table C.
You may need to control the order in which the rows are posted to the DB to avoid this problem. Read Advanced Entity Object Techniques - 11g Release 1 (11.1.1.6.0) to get more info about this.
However, sometimes it's easier to control the generation and setting if the PK attributes in the model layer, not relating on db triggers where you get the real values only after the commit operation is done in the db. For this you can use a Groovy expression so you have access to the PK of each new created row right after creation. Read Using Groovy Expression to set a Primary Key with a Sequence Number | JDev & ADF Goodies to find out how to do this.
Timo
Similar Messages
-
How to build a screen with master detail data
Hi ,expert ,
Someone can teach me how to build a screen with master detail table ?
I wnat to build a screen for user to maintain FERT group and FERT detail list in one screen .
just like this ..
MASTER Block
FERT1
FERT2
FERT3
DETAIL Block
FERT1A1
FERT1A2
FERT1A3
when I double click FERT1 in the Master Block the detail view will show FERT1A1 A2 A3
Thanks for your help ....
Moderator message : Not enough research before posting. Spec dumping not allowed. Thread locked.
Edited by: Vinod Kumar on Jun 13, 2011 1:38 PMAn inefficient way to create the array is to use the build array and a shift register as shown below. It's more effecient in terms of memory management to create the array and then use the replace array subset as shown in the other image. Of course, if you don't need the array inside the loop, just wire the value out of the while loop and on the exit tunnel, right click and select 'Enable Indexing'.
Message Edited by Dennis Knutson on 07-03-2007 10:25 PM
Message Edited by Dennis Knutson on 07-03-2007 10:26 PM
Attachments:
Crude Build Array.PNG 4 KB
Better Build Array.PNG 6 KB -
Problem occured when create a tree table for master-detail view objects using SQL queries?
I am programming a tree table for master-detail view objects using SQL queries and these 2 view objects are not simple singel tables queries, and 2 complex SQL are prepared for master and view objects. see below:
1. Master View object (key attribute is SourceBlock and some varaible bindings are used for this view object.)
SELECT cntr_list.SOURCE_BLOCK,
sum(
case when cntr_list.cntr_size_q = '20'
then cntr_list.cntr_qty
else 0 end ) as cntr20 ,
sum(
case when cntr_list.cntr_size_q = '40'
then cntr_list.cntr_qty
else 0 end ) as cntr40 ,
sum(
case when cntr_list.cntr_size_q = '45'
then cntr_list.cntr_qty
else 0 end ) as cntr45
FROM (
SELECT yb1.BLOCK_M as SOURCE_BLOCK,
scn.CNTR_SIZE_Q,
count(scn.CNTR_SIZE_Q) AS cntr_qty
FROM SHIFT_CMR scm, SHIFT_CNTR scn, YARD_BLOCK yb1, YARD_BLOCK yb2
WHERE
scm.cmr_n = scn.cmr_n
AND (scm.plan_start_dt BETWEEN to_date(:DateFrom,'YYYY/MM/DD HH24:MI:SS') AND to_date(:DateTo,'YYYY/MM/DD HH24:MI:SS')
OR scm.plan_end_dt BETWEEN to_date(:DateFrom,'YYYY/MM/DD HH24:MI:SS') AND to_date(:DateTo,'YYYY/MM/DD HH24:MI:SS'))
AND scm.shift_mode_c = :ShiftModeCode
AND scm.end_terminal_c = :TerminalCode
AND scm.start_terminal_c = yb1.terminal_c
AND scm.start_block_n = yb1.block_n
AND substr(scn.start_location_c,(instr(scn.start_location_c,',',1,5)+1),instr(scn.start_location_c,',',1,6)-(instr(scn.start_location_c,',',1,5)+1)) BETWEEN yb1.slot_from_n AND yb1.slot_to_n
AND scm.end_terminal_c = yb2.terminal_c
AND scm.end_block_n = yb2.block_n
AND substr(scn.end_location_c,(instr(scn.end_location_c,',',1,5)+1),instr(scn.end_location_c,',',1,6)-(instr(scn.end_location_c,',',1,5)+1)) BETWEEN yb2.slot_from_n AND yb2.slot_to_n
AND scn.status_c not in (1, 11)
AND scn.shift_type_c = 'V'
AND scn.source_c = 'S'
GROUP BY yb1.BLOCK_M, scn.CNTR_SIZE_Q
) cntr_list
GROUP BY cntr_list.SOURCE_BLOCK
2. Detail View object (key attributes are SourceBlock and EndBlock and same varaible bindings are used for this view object.)
SELECT cntr_list.SOURCE_BLOCK, cntr_list.END_BLOCK,
sum(
case when cntr_list.cntr_size_q = '20'
then cntr_list.cntr_qty
else 0 end ) as cntr20 ,
sum(
case when cntr_list.cntr_size_q = '40'
then cntr_list.cntr_qty
else 0 end ) as cntr40 ,
sum(
case when cntr_list.cntr_size_q = '45'
then cntr_list.cntr_qty
else 0 end ) as cntr45
FROM (
SELECT yb1.BLOCK_M as SOURCE_BLOCK,
yb2.BLOCK_M as END_BLOCK,
scn.CNTR_SIZE_Q,
count(scn.CNTR_SIZE_Q) AS cntr_qty
FROM SHIFT_CMR scm, SHIFT_CNTR scn, YARD_BLOCK yb1, YARD_BLOCK yb2
WHERE
scm.cmr_n = scn.cmr_n
AND (scm.plan_start_dt BETWEEN to_date(:DateFrom,'YYYY/MM/DD HH24:MI:SS') AND to_date(:DateTo,'YYYY/MM/DD HH24:MI:SS')
OR scm.plan_end_dt BETWEEN to_date(:DateFrom,'YYYY/MM/DD HH24:MI:SS') AND to_date(:DateTo,'YYYY/MM/DD HH24:MI:SS'))
AND scm.shift_mode_c = :ShiftModeCode
AND scm.end_terminal_c = :TerminalCode
AND scm.start_terminal_c = yb1.terminal_c
AND scm.start_block_n = yb1.block_n
AND substr(scn.start_location_c,(instr(scn.start_location_c,',',1,5)+1),instr(scn.start_location_c,',',1,6)-(instr(scn.start_location_c,',',1,5)+1)) BETWEEN yb1.slot_from_n AND yb1.slot_to_n
AND scm.end_terminal_c = yb2.terminal_c
AND scm.end_block_n = yb2.block_n
AND substr(scn.end_location_c,(instr(scn.end_location_c,',',1,5)+1),instr(scn.end_location_c,',',1,6)-(instr(scn.end_location_c,',',1,5)+1)) BETWEEN yb2.slot_from_n AND yb2.slot_to_n
AND scn.status_c not in (1, 11)
AND scn.shift_type_c = 'V'
AND scn.source_c = 'S'
GROUP BY yb1.BLOCK_M, yb2.BLOCK_M, scn.CNTR_SIZE_Q
) cntr_list
GROUP BY cntr_list.SOURCE_BLOCK, cntr_list.END_BLOCK
3. I create a view link to create master-detail relationship for these 2 view objects.
masterview.SourceBlock (1)->detailview.SourceBlock (*).
4. I create a tree table using these 2 view objects with master-detail relationship.
When I set default value for variable bindings of these 2 view objects and the matching records exist, tree table can work well. I can expand the master row to display detail row in UI.
But I need to pass in dymamic parameter value for variable bindings of these 2 view objects, tree table cannnot work again. when I expand the master row and no detail row are displayed in UI.
I am sure that I pass in correct parameter value for master/detail view objects and matching records exist.
Managed Bean:
DCIteratorBinding dc = (DCIteratorBinding)evaluteEL("#{bindings.MasterView1Iterator}");
ViewObject vo = dc.getViewObject();
System.out.println("Before MasterView1Iterator vo.getEstimatedRowCount()="+ vo.getEstimatedRowCount());
System.out.println("Before MasterView1Iterator ShiftModeCode="+ vo.ensureVariableManager().getVariableValue("ShiftModeCode"));
vo.ensureVariableManager().setVariableValue("DateFrom", dateFrom);
vo.ensureVariableManager().setVariableValue("DateTo", dateTo);
vo.ensureVariableManager().setVariableValue("ShiftModeCode", shiftModeC);
vo.ensureVariableManager().setVariableValue("TerminalCode", terminalCode);
vo.executeQuery();
System.out.println("MasterView1Iterator vo.getEstimatedRowCount()="+ vo.getEstimatedRowCount());
DCIteratorBinding dc1 = (DCIteratorBinding)evaluteEL("#{bindings.DetailView1Iterator}");
ViewObject vo1 = dc1.getViewObject();
System.out.println("Before DetailView1Iterator vo1.getEstimatedRowCount()="+ vo1.getEstimatedRowCount());
System.out.println("Before DetailView1Iterator ShiftModeCode="+ vo1.ensureVariableManager().getVariableValue("ShiftModeCode"));
vo1.ensureVariableManager().setVariableValue("DateFrom", dateFrom);
vo1.ensureVariableManager().setVariableValue("DateTo", dateTo);
vo1.ensureVariableManager().setVariableValue("ShiftModeCode", shiftModeC);
vo1.ensureVariableManager().setVariableValue("TerminalCode", terminalCode);
vo1.executeQuery();
System.out.println("after DetailView1Iterator vo1.getEstimatedRowCount()="+ vo1.getEstimatedRowCount());
5. What's wrong in my implementation? I don't have no problem to implement such a tree table if using simple master-detail tables view object, but now I have to use such 2 view objects using complex SQL for my requirement and variable bindings are necessary for detail view object although I also think a bit strange by myself.Hi Frank,
Thank you and it can work.
public void setLowHighSalaryRangeForDetailEmployeesAccessorViewObject(Number lowSalary,
Number highSalary) {
Row r = getCurrentRow();
if (r != null) {
RowSet rs = (RowSet)r.getAttribute("EmpView");
if (rs != null) {
ViewObject accessorVO = rs.getViewObject();
accessorVO.setNamedWhereClauseParam("LowSalary", lowSalary);
accessorVO.setNamedWhereClauseParam("HighSalary", highSalary);
executeQuery();
but I have a quesiton in this way. in code snippet, it is first getting current row of current master VO to determine if update variables value of detail VO. in my case, current row is possibly null after executeQuery() of master VO and I have to change current row manually like below.
any idea?
DCIteratorBinding dc = (DCIteratorBinding)ADFUtil.evaluateEL("#{bindings.SSForecastSourceBlockView1Iterator}");
ViewObject vo = dc.getViewObject();
vo.ensureVariableManager().setVariableValue("DateFrom", dateFrom);
vo.ensureVariableManager().setVariableValue("DateTo", dateTo);
vo.ensureVariableManager().setVariableValue("ShiftModeCode", shiftModeC);
vo.ensureVariableManager().setVariableValue("TerminalCode", terminalCode);
vo.executeQuery();
vo.setCurrentRowAtRangeIndex(0);
((SSForecastSourceBlockViewImpl)vo).synchornizeAccessorVOVariableValues(); -
Issue with Master Detail relation in OAF page -- Help
Hi,
I am developing an OA page with a master detail relation. The detail records are displayed in the subtab region.
The issue that I am facing is as follows:
If there are 2 detail records in the detail table, then my page is displaying these 2 records twice i.e.
Detail Records:
Header Id Line Id
2 1
3 1
Header Id Line Id
2 1
3 1
If the number of detail record increases, then again the display also increases that many times i.e. 3 records gets displayed thrice.
Kindly help to figure out the issue.
Thanks In Advance.Hi,
Take the following actions.
1. Try to display your records in simple Table and remove it from subtab,
2. check relations as well, you can delete and re-create all the relations with EOs and VOs and recreate them.
3. Also check when your VO get popluated that how many rows are there in Detail VO ?
For example.
int x = yourViewObject.getRowCount();
System.out.println("Number of rows in detail view Object"+x);
Haroon. -
Multiselection in Tables with Master Column
The use case is the following:
I have a table with a master column in which I display a tree. The table is bound to a dataSource with a recursive node.
I'd like to implement multiple selection for the rows of this table, but it doesn't work (even when making context node's selection 0..n).
Is there any work-around for solving this problem?Thanks for the suggestion.
But there is still problem with this:
I will have have two methods for selection of rows of the table - there will be standart one which is provided by webdynpro and additionaly I will have a column of checkboxes. It is not convinient form user-perspective. Furthermore I can't put columns on the left of the master column which is also a problem, the checkboxes should be situated in the firs column.
Regards, Vasil -
Problem with Master Detail between 3 tables or more
Hi to the community, I have the following problem.
I have 3 tables relationship : table Solicitud, ItemSolicitado,Cotizacion
Solicitud - ItemSolicitado ( 1 to * relationship )
ItemSolicitado - Cotizacion ( 1 to * relationship )
Solicitud - Cotizacion ( 1 to * relationship )
I have a Master Detail between Solicitud/ItemSolicitado , and it run correctly, I Insert,update,delete correctly ( with expression Groovy )
I want make a master/detail between ( Solicitud/ItemSolicitado ) / Cotizacion , because I need insert some data in Cotizacion table with some data from Solicitud/ItemSolicitado.
The user see the Master/Detail between the Solicitud/ItemSolicitado Tables, and when the user select a item from the detail ( ItemSolicitado ) I want insert data into Cotizacion Table with the Solicitud Primary key and ItemSolicitado primary key
How I can make a Master Detail between 3 tables or more ?? or, How I can do what I want ? some idea ??
Thanks.I resolved it !!, Only create a view link between the tables and I define in the Data Model Tab of my application module, as following, and it run !!
+Solicitud // parent
+ItemSolicitado // child 1
+Cotizacion // child2 -
Selection in table with Master Column
Hi,
can anybody explain me how selection works in table with MasterColumn (TreeByNestingTableColumn)?
I've created a table with several columns and the "master" one behaves differently from others.
First of all, leaf elements of master column are not clickable (i.e. I don't receive notification "onLeadSelect" from the table, when user clicks in the cell of leaf element of the column). With expandable elements I receive loadchildren event and can react on selection.
I'm using TextView as cell editor, will try LinkToAction, may be it will resolve situation, but it's rather workaround as solution
Second, getLeadSelection doesn't work anymore for the table - it works with indexes of top level elements only.
However onLeadSelect action brings me selected row number, which I somehow should map to the tree.
I.e. when I get "25" as selected element, I recursively traverse context node to find 25th element. Which is rather slow operation as for any selection I have to reiterate whole structure and I hope that visual appearance is similar to context element order.
May be there is simplier ways to get selected element by its index in "flat" list?
And one another strange thing: first click on the table sends me onLeadSelect "0", but highlight points to the element user clicked - not necessary first one.
Context node is "single" selection, initLeadSelect=true,
selection = 0..1 (with 1..1 setTreeSelection doesn't work - method I want to use to be able to select a node in hierarchy on my own)
all quite similar to other tables I have, which works well. Just the problems with the table, where Master Column is used.
Thank you!
Best regards,
Nick>Valery's proposal was to perform reverse traverse from current element to root and summarize parent element indexes.
It seems to work:
in method, which sets selection I applied
// we need to know index of the element not in whole context, but in scope of table-relevant node
int index = getIndexInContext(selElement, wdContext.currentXXXElement());
IContextElement curContext = wdContext.currentContextElement();
int firstVisibleRow = curContext.getTableFirstVisibleRow();
int visibleRows = curContext.getTableVisibleRows();
if (index < firstVisibleRow || index > firstVisibleRow + visibleRows) {
curContext.setTableFirstVisibleRow(index);
and method getIndexInContext looks as:
private int getIndexInContext (IWDNodeElement element, IWDNodeElement root) {
int index = element.index();
if (element == root) {
return index;
IWDNodeElement parent = element.node().getParentElement();
if (parent == null) {
// do whatever you like here for error diagnostic
myMsgMgr.reportException("Internal Error: getIndexInContext - element is not under passed root", false);
return 0;
// +1 - every level adds 1 (otherwise indexes of first children of hierarchy will be 0)
return index + getIndexInContext(parent, root) + 1;
Best regards,
Nick -
Master advance table with two detail advanced tables
Hi All,
I have this in mind..please let me know if that is possible.
I want to have two detail advanced tables within a master advance table.
The two detail advance tables will be wrapped in a subtab layout.
My questions are:
Can a master table have two details tables?
Can a advance table have two inner advance tables?
Your help or ideas would be valuable to me.
Thank you,
ArunHi OAF Gurus
I just want to know whether this is possible or not.
I have created two view links and three view objects
Table in Table in Table
Table1--> Table2 --> Table3
One problem i am facing when i click on Show link of Table1,it displays details of Table2 and when i click Show link of Table2,it displays details of Table3.
but when i click on Hide of Table1, it says
oracle.jbo.NoDefException: JBO-25002: Definition <Table3 View Object> of type Attribute not found
Could you please anybody throw some pointers on this?
Thanks
Hitesh -
Problem with Master -Details forms in seperate pages
Hi ,
Below is the scenario:
I have Institution and a department tables where there is a foreign key relation between the tables. So now i have two entity objects for the 2 tables and 2 view objects(DepartmentView,InstitutionView) from the entity objects.
I also have a view link between them.I made a master-detail relation between them in the datamodel using the view link.So my appmodule now has getters for the department view,institution view and viewlink.
I now have a jsp page "createInstitution.jsp" which contains a form for the institution , i have a "next" button on the same jsp which calls a method in my appmodule class .This methods just inserts the record into the Institution view. In this method i am able to see what the user entered in the form by getting the viewrow record like the below code :
InstitutionViewRowImpl newInstitutionRow=(InstitutionViewRowImpl) getInstitutionView().first();
The next button navigates to the next page "listDepartments.jsp" which contains the list of departments that are added. This page has a button "Add Department" which takes to to the "addDepartment.jsp" page which shows a form for adding a department. This page also has a button which calls a method in app module class. The method just inserts the record into the view(DepartmentView)
Here when i say
DepartmentViewRowImpl newDepartmentRow=(DepartmentViewRowImpl ) getDepartmentView().first();
the newDepartmentRow is null.
Also on the addDepartment.jsp form , i had used a output field to see what the parent id was and interestingly the parent id is 75 which is first institution in the database. It should have been "-10" , a temporary id assigned.
Can someone please tell me what is the problem with my approach?I don't understand why you are using a method on your button to insert the record into the table - An Oracle ADF Form will do the insert for you by default without any coding.
See the create pages in these tutorials:
http://www.oracle.com/technology/products/jdev/11/cuecards/adf_set_21/ccset21_ALL.html
http://www.oracle.com/technology/obe/obe11jdev/11/dev_ui/developuserinterface.html#t2s5
The method that you are calling just returns the first record in the rowset - I don't see how it has anything to do with actually inserting the data into the table. -
Procedure Based Form with master details Relationships
Helo All
Here i m having some problem in making one form which is having 2 tables one is master and other is detail table and i already made relationship between them but still i make both forms at that moment form didn't make the auto relationship.even after taht when at the form level i made the relationship between 2 tables it made but at teh compilation time it gives error.
Actually one table was there at that time it worked but with relation it creates problem.
Can anybody give me any idea how to sort out this problem.Helo Frankin
Actualy the error came when i made the master detail relation manualy.but as per me if both tables have relationship with each other then no need to create it manualy isn't it?
even after that i created teh relation manaualy but at the on clear block details trigger it showed compile time error.
If possible can u give me any live example for this
TQ
Vivek -
Need help with master detail from different datasets
I have xml data from three different datasets that I want to use in a master detail region.
So initially, a list of model codes is displayed. When the user clicks on a specific model, the model inputs appear in the detail region. One of these inputs is a list of map units. I also want a real name description of the map unit to be displayed. It's working for one map code, but not for all of them.
My question is: "How do I get the description to disply for each of the map codes?"
Here is my code:
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Untitled Document</title>
<script src="/SpryAssets/xpath.js" type="text/javascript"></script>
<script src="/SpryAssets/SpryData.js" type="text/javascript"></script>
<link href="/SpryAssets/SprySpotlightColumn.css" rel="stylesheet" type="text/css" />
<script type="text/javascript">
var DSpresence = new Spry.Data.XMLDataSet("/SpeciesReview/Copy of tblSppMapUnitPres.xml", "dataroot/Copy_x0020_of_x0020_tblSppMapUnitPres");
var DSancillary = new Spry.Data.XMLDataSet("/SpeciesReview/ModelingAncillarywname.xml", "dataroot/Sheet1", {sortOnLoad: "CommonName", sortOrderOnLoad: "ascending"});
var DSpresence2 = new Spry.Data.XMLDataSet("/SpeciesReview/Copy of tblSppMapUnitPres.xml", "dataroot/Copy_x0020_of_x0020_tblSppMapUnitPres[strSpeciesModelCode='DSancillary::strSpec iesModelCode']");
var dsMUDescription = new Spry.Data.XMLDataSet("/SpeciesReview/tblMapUnitDesc.xml", "dataroot/tblMapUnitDesc");
var dsMUDescription2= new Spry.Data.XMLDataSet("/SpeciesReview/tblMapUnitDesc.xml", "dataroot/tblMapUnitDesc[intLSGapMapCode='{DSpresence2::intLSGapMapCode}']");
</script>
</head>
<body>
<div style="width: 100%">
<div id="Species_DIV" spry:region="DSancillary DSpresence dsMUDescription" width="50%" style="float:left">
<table id="DSancillary">
<tr>
<th>Species Code</th>
</tr>
<tr spry:repeat="DSancillary" "DSpresence" "dsMUDescription" spry:setrow="DSancillary" >
<td>{strSpeciesModelCode}</td>
</tr>
</table>
</div>
<div id="Species_Detail_DIV" spry:detailregion="DSancillary DSpresence dsMUDescription" style="float:right; margin-top:20px; width: 40%">
<table id="Species_Detail_Table" >
<tr width="100%">
<th style="font-family:Verdana, Geneva, sans-serif; font-size:14px; background-color:#CCCCCC; font-weight:bold">Modeling variables used for {strSpeciesModelCode}</th>
</tr>
<tr>
<td spry:if="'{memModelNotes}' != ''">Hand Model Notes: {DSancillary::memModelNotes}</td></tr>
<tr>
<td spry:if="'{DSancillary::ysnHydroFW}' == 1">HydroFW: {DSancillary::ysnHydroFW}<br />Buffer from flowing water: {DSancillary::intFromBuffFW}<br />
Buffer into flowing water: {DSancillary::intIntoBuffFW}
</td></tr>
<tr>
<td spry:if="'{DSancillary::ysnHydroOW}' == 1"> Buffer from open water: {DSancillary::intFromBuffFW}<br />Buffer into open water: {DSancillary::intIntoBuffOW}</td></tr>
<tr><td><br /></td></tr>
<tr><th>Mapcode:</th></tr>
<tr spry:repeat="DSpresence">
<td spry:if="'{DSpresence::ysnPres}' == '1'">{DSpresence::intLSGapMapCode}</td><td spry:if= "'{DSpresence::intLSGapMapCode}'=='{dsMUDescription::intLSGapMapCode}'">{dsMUDescription: :strLSGapName}</td>
</tr>
<tr><td><ul>
<li spry:repeat="DSpresence" spry:if="'{DSpresence::ysnPres}' == '1'">{DSpresence::intLSGapMapCode}{dsMUDescription::intLSGapMapCode}</li>
</ul></td></tr>
</table>
</div>
</div>
</body>The best way to do this is to use xPath filtering. This http://labs.adobe.com/technologies/spry/samples/data_region/FilterXPath_with_params.html example will give you the general idea.
The example uses a URL variable but there is no need for that if you use a procedure similar to
function newXPath(cat){
DSpresence.setXPath("dataroot/Copy_x0020_of_x0020_tblSppMapUnitPres[strSpeciesModelCode=' {DSpresence::strSpeciesModelCode}']");
DSpresence.loadData();
The function can be triggered with an onclick event placed on {strSpeciesModelCode}
Gramps -
Issue with Master Detail OAF Page
Hi Friends,
I have an issue with the Master-Detaiil Page.
I have developed a Master-detail form in OAF similar to the one in Oracle Forms. The master details are appearing fine. I have created a transient variable selectFlag that represents if the master record is selected. I am also able to see the detailed records after I have written the code in CO to populate the details table when a master is chosen.
But in the detail table I am seeing all the records. I should be able to see only the records that are children for the master record.
I have created the ViewLink as well. How can I pass the id of the master record to the detail table.
Any ideas. Kindly help.
ThanksHi,
Are u using partialAction on master form for this ?
You can add parameters from property inspector and put some unique attribute from VO and later filter the details record based on that.
--Sushant -
OBIEE 11g: Inconsistencies with Master-Detail events and Navigate to BI
Hi everyone,
I'm getting some pretty annoying inconsistencies with the Navigate to BI Content action as well as the Master-Detail events. Basically the main issue I get is that 90% of the time, the click does nothing.
It's a pretty simple setup, I am setting up bulb gauges to act like a fancy column selector. The bulb gauges are setup to pivot based on a Metric Type column. The goal is that if you click on "Metric 1" bulb a trend report should refresh to show Metric 1. If you click on the "Metric 2" bulb, the same trend report will show that metric.
Here's how I implemented it:
Dashboard Tab A -- Uses Navigate to BI Content
1) I have a prompt on Fiscal month in dashboard tab A.
2) I created the bulb gauge and put it in dashboard tab A
3) Setup the interaction on the bulb measure to navigate back to Dashboard Tab A.
3) Prompted the trend on Metric Type column and put it in dashboard tab A.
4) In theory, clicking on the bulb, should navigate back to the same tab and update the trend report appropriately
5) In reality, nothing happens.
6) The only way I can get the navigate to work is if I first change the value in the fiscal month prompt and click Go. Then I click on the bulb and the navigation will work ONCE. After that it's broken again.
Dashboard Tab B -- Use Master Detail -Events
1) Pretty much same situation as dashboard A, but instead of navigate to BI Content, I use the master-detail events.
2) Pretty much the same results. I cannot get it to consistently work, in fact the trick with the filter didn't do anything.
3) One thing I tried was cleared my browser history completely (Mozilla Firefox) and then launched the page. It work for about 5 clicks and then stopped.
Either way, neither of these are working properly for me.
Has anyone else had these issues?
-=Joe
Has anyone else had an issue with this?So someone explained to me that master-detail events only occur within a single report. They cannot be used to communicate across two different reports.
That is significantly less useful than I originally thought. I honestly that it was a method of communication for one report to update other target reports that are all listening on the same channel. That would have been a powerful feature. A single report refreshing other views in the same report is still useful, but not as much.
That being said, I still don't understand what the heck is going on with the navigate to BI content feature. I've been testing it out. It works with pivot tables and regular tables. But the moment I add a graph, gauge or even a "Filter" view into the dashboard page, the click stops working. Really really strange stuff. -
Detail-Disclosure problem with Master- Detail VO
Hi,
I have UIX pages based on Master - Detail VO, detail data being shown when you press Detail button on the left, detail data display in the BC4J Table correctly, but I am able to update only the last record of the rowset. when I click on the first master detail and press update button i get Null Pointer Exeception error and other problem is that my detail data has sorted headers, when i click on the sorted column header, it close the Detail portion on the Table.
Here is UIX page listing, please any one review the code and let me what is wrong
Thanks
View Page
<?xml version="1.0" encoding="windows-1252" ?>
<page xmlns="http://xmlns.oracle.com/uix/controller"
xmlns:ctrl="http://xmlns.oracle.com/uix/controller"
xmlns:ui="http://xmlns.oracle.com/uix/ui"
xmlns:bc4j="http://xmlns.oracle.com/uix/bc4j"
xmlns:html="http://www.w3.org/TR/REC-html40"
xmlns:viewpage="http://www.example.org/siriusbilling/templates">
<ctrl:head xmlns="http://www.w3.org/TR/REC-html40">
<title>View Properties</title>
</ctrl:head>
<templates xmlns="http://xmlns.oracle.com/uix/ui">
<templateImport source="templates/SiriusBilling.uit"/>
</templates>
<bc4j:registryDef>
<bc4j:rootAppModuleDef name="PropertiesForeignKeyLink1AppModule"
definition="siriusbilling.SiriusBCModule"
releaseMode="stateful" >
<bc4j:viewObjectDef name="PropertyTypesMasterView"
rangeSize="2" />
<bc4j:viewObjectDef name="PropertiesDetailView"
rangeSize="5" />
</bc4j:rootAppModuleDef>
</bc4j:registryDef>
<ctrl:content xmlns="http://xmlns.oracle.com/uix/ui"
xmlns:data="http://xmlns.oracle.com/uix/ui">
<viewpage:siriusPageLayout>
<pageHeader>
<globalHeader selectedIndex="0">
<contents>
<link text="View Properties" />
</contents>
</globalHeader >
</pageHeader>
<contents>
<try xmlns="http://xmlns.oracle.com/uix/ui"
xmlns:data="http://xmlns.oracle.com/uix/ui" >
<catch>
<displayException />
</catch>
<contents>
<!-- this will contain any validation errors after form
submission -->
<messageBox automatic="true" />
<bc4j:rootAppModuleScope name="PropertiesForeignKeyLink1AppModule" >
<contents>
<header text="Properties Search" >
<contents>
<form name="search" method="POST" >
<contents>
<inlineMessage prompt="Search by:" vAlign="middle" >
<contents>
<bc4j:viewObjectScope name="PropertiesDetailView" >
<contents>
<flowLayout>
<contents>
<choice name="attrName"
data:selectedValue="attrName@ctrl:page"
shortDesc="Search Column">
<contents>
<option text="Property Id" value="PropertyId" />
<option text="Property Name" value="PropertyName" />
<option text="Property Description" value="PropertyDescription" />
<option text="Unit Of Measure" value="UnitOfMeasure" />
</contents>
</choice>
<textInput prompt="Criteria" name="attrValue" columns="20"
data:text="attrValue@ctrl:page"
shortDesc="Search Criteria for Propeties"/>
</contents>
</flowLayout>
</contents>
</bc4j:viewObjectScope>
</contents>
<end>
<submitButton text="Go" ctrl:event="search" />
</end>
</inlineMessage>
</contents>
</form>
</contents>
</header>
<spacer width="10"/>
<separator />
<header text="Property Types" >
<contents>
<form name="viewForm" method="POST" >
<contents>
<bc4j:viewObjectScope name="PropertyTypesMasterView" >
<contents>
<bc4j:table name="viewPropertyTypeTable" automatic="false"
width="100%" alternateText="No rows found"
formSubmitted="true"
partialRenderMode="self"
data:detailDisclosure="tableDetails@ctrl:eventResult">
<!-- the key identifying the current row in the table -->
<bc4j:keyStamp>
<bc4j:rowKey name="key" />
</bc4j:keyStamp>
<contents>
<!-- placing the region in automatic mode will cause the key
named child to be rendered, followed by each attribute
in the ViewObject using the attrStamp named child. -->
<!-- A bc4j:column element is added for each attribute
in the ViewObject. -->
<bc4j:column attrName="PropertyType">
<columnHeader>
<bc4j:sortableHeader text="Property Type"/>
</columnHeader>
<contents>
<bc4j:input readOnly="true"/>
</contents>
</bc4j:column>
<bc4j:column attrName="TableName">
<columnHeader>
<bc4j:sortableHeader text="Table Name"/>
</columnHeader>
<contents>
<bc4j:input readOnly="true"/>
</contents>
</bc4j:column>
<bc4j:column attrName="Comments" >
<columnHeader>
Comments
</columnHeader>
<contents>
<bc4j:input readOnly="true"/>
</contents>
</bc4j:column>
</contents>
<detail>
<flowLayout>
<contents>
<header text="Properties Detail">
<contents>
<spacer width="10"/>
<bc4j:viewObjectScope name="PropertiesDetailView" >
<contents>
<!-- placing the table in automatic mode will cause the table
to contain the keyStamp named child followed by the
columnStamp named child for each attribute in the
ViewObject. -->
<bc4j:table name="viewTable" automatic="false"
width="100%" alternateText="No rows found"
formSubmitted="true"
partialRenderMode="self">
<tableSelection>
<!-- single selection for each row in the table -->
<singleSelection selectedIndex="0" text="Select Row and ...">
<contents>
<submitButton text="Create" ctrl:event="create" />
<!-- the update button causes the currently selected
row to be sent to the update page -->
<submitButton text="Update"
ctrl:event="update" />
<!-- the delete button causes the currently selected
row to be removed -->
<submitButton text="Delete"
ctrl:event="delete" />
</contents>
</singleSelection>
</tableSelection>
<!-- the key identifying the current row in the table -->
<bc4j:keyStamp>
<bc4j:rowKey name="key" />
</bc4j:keyStamp>
<contents>
<!-- A bc4j:column element is added for each attribute
in the ViewObject. -->
<bc4j:column attrName="PropertyId">
<columnHeader>
<bc4j:sortableHeader text="Property Id"/>
</columnHeader>
<contents>
<bc4j:input readOnly="true"/>
</contents>
</bc4j:column>
<bc4j:column attrName="PropertyName">
<columnHeader>
<bc4j:sortableHeader text="Property Name"/>
</columnHeader>
<contents>
<bc4j:input readOnly="true"/>
</contents>
</bc4j:column>
<bc4j:column attrName="PropertyDescription">
<columnHeader>
<bc4j:sortableHeader text="Property Description"/>
</columnHeader>
<contents>
<bc4j:input readOnly="true"/>
</contents>
</bc4j:column>
<bc4j:column attrName="UnitOfMeasure">
<columnHeader>
<bc4j:sortableHeader text="Unit of Measure"/>
</columnHeader>
<contents>
<bc4j:input readOnly="true"/>
</contents>
</bc4j:column>
</contents>
</bc4j:table>
</contents>
</bc4j:viewObjectScope>
<formValue name="disclosed" value="true" />
</contents>
</header>
</contents>
</flowLayout>
</detail>
</bc4j:table>
</contents>
</bc4j:viewObjectScope>
</contents>
</form>
</contents>
</header>
</contents>
</bc4j:rootAppModuleScope>
</contents>
</try>
</contents>
</viewpage:siriusPageLayout>
</ctrl:content>
<handlers>
<event name="search" >
<!-- using the ApplicationModule causes it to be checked out from the
ApplicationPool. It is released using stateful mode. -->
<bc4j:findRootAppModule name="PropertiesForeignKeyLink1AppModule" >
<!-- establish the ViewObject scope -->
<bc4j:findViewObject name="PropertiesDetailView" >
<!-- search for the view criteria -->
<bc4j:findByExample>
<bc4j:exampleRow ignoreCase="true" >
<bc4j:exampleAttribute>
<bc4j:nameBinding><bc4j:parameter name="attrName" /></bc4j:nameBinding>
<bc4j:valueBinding><bc4j:parameter name="attrValue" /></bc4j:valueBinding>
</bc4j:exampleAttribute>
</bc4j:exampleRow>
</bc4j:findByExample>
<bc4j:executeQuery/>
<!-- store the current search criteria as page properties -->
<bc4j:setPageProperty name="attrName" >
<bc4j:parameter name="attrName" />
</bc4j:setPageProperty>
<bc4j:setPageProperty name="attrValue" >
<bc4j:parameter name="attrValue" />
</bc4j:setPageProperty>
</bc4j:findViewObject>
</bc4j:findRootAppModule>
</event>
<event name="first" >
<!-- using the ApplicationModule causes it to be checked out from the
ApplicationPool. It is released using stateful mode. -->
<bc4j:findRootAppModule name="PropertiesForeignKeyLink1AppModule" >
<!-- establish the ViewObject scope -->
<bc4j:findViewObject name="PropertyTypesMasterView" >
<!-- navigate to the first department -->
<bc4j:first/>
</bc4j:findViewObject>
</bc4j:findRootAppModule>
</event>
<event name="previous" >
<!-- using the ApplicationModule causes it to be checked out from the
ApplicationPool. It is released using stateful mode. -->
<bc4j:findRootAppModule name="PropertiesForeignKeyLink1AppModule" >
<!-- establish the ViewObject scope -->
<bc4j:findViewObject name="PropertyTypesMasterView" >
<!-- navigate to the previous department -->
<bc4j:previous/>
</bc4j:findViewObject>
</bc4j:findRootAppModule>
</event>
<event name="next" >
<!-- using the ApplicationModule causes it to be checked out from the
ApplicationPool. It is released using stateful mode. -->
<bc4j:findRootAppModule name="PropertiesForeignKeyLink1AppModule" >
<!-- establish the ViewObject scope -->
<bc4j:findViewObject name="PropertyTypesMasterView" >
<!-- navigate to the next department -->
<bc4j:next/>
</bc4j:findViewObject>
</bc4j:findRootAppModule>
</event>
<event name="last" >
<!-- using the ApplicationModule causes it to be checked out from the
ApplicationPool. It is released using stateful mode. -->
<bc4j:findRootAppModule name="PropertiesForeignKeyLink1AppModule" >
<!-- establish the ViewObject scope -->
<bc4j:findViewObject name="PropertyTypesMasterView" >
<!-- navigate to the last department -->
<bc4j:last/>
</bc4j:findViewObject>
</bc4j:findRootAppModule>
</event>
<event name="sort" source="viewTable" >
<!-- using the ApplicationModule causes it to be checked out from the
ApplicationPool. It is released using stateful mode. -->
<bc4j:findRootAppModule name="PropertiesForeignKeyLink1AppModule" >
<!-- establish the ViewObject scope -->
<bc4j:findViewObject name="PropertiesDetailView" >
<!-- sort by the submitted attribute name -->
<bc4j:sort/>
</bc4j:findViewObject>
</bc4j:findRootAppModule>
</event>
<event name="sort" source="viewPropertyTypeTable" >
<!-- using the ApplicationModule causes it to be checked out from the
ApplicationPool. It is released using stateful mode. -->
<bc4j:findRootAppModule name="PropertiesForeignKeyLink1AppModule" >
<!-- establish the ViewObject scope -->
<bc4j:findViewObject name="PropertyTypesMasterView" >
<!-- sort by the submitted attribute name -->
<bc4j:sort/>
</bc4j:findViewObject>
</bc4j:findRootAppModule>
</event>
<event name="goto" source="viewPropertyTypeTable" >
<!-- using the ApplicationModule causes it to be checked out from the
ApplicationPool. It is released using stateful mode. -->
<bc4j:findRootAppModule name="PropertiesForeignKeyLink1AppModule" >
<!-- establish the ViewObject scope -->
<bc4j:findViewObject name="PropertyTypesMasterView" >
<!-- navigate to the submitted range -->
<bc4j:goto/>
</bc4j:findViewObject>
</bc4j:findRootAppModule>
</event>
<event name="goto" source="viewTable" >
<!-- using the ApplicationModule causes it to be checked out from the
ApplicationPool. It is released using stateful mode. -->
<bc4j:findRootAppModule name="PropertiesForeignKeyLink1AppModule" >
<!-- establish the ViewObject scope -->
<bc4j:findViewObject name="PropertiesDetailView" >
<!-- navigate to the submitted range -->
<bc4j:goto/>
</bc4j:findViewObject>
</bc4j:findRootAppModule>
</event>
<event name="create" >
<!-- forward to the create page -->
<ctrl:go name="InsertProperties" redirect="true" />
</event>
<event name="update" >
<!-- forward to the update page, passing the selected key
as a page property -->
<ctrl:go name="UpdateProperties" redirect="true" >
<ctrl:property name="key" >
<ctrl:selection name="viewTable" key="key" />
</ctrl:property>
</ctrl:go>
</event>
<event name="delete" >
<!-- using the ApplicationModule causes it to be checked out from the
ApplicationPool. It is released using stateful mode. -->
<bc4j:findRootAppModule name="PropertiesForeignKeyLink1AppModule" >
<!-- establish the ViewObject scope -->
<bc4j:findViewObject name="PropertiesDetailView" >
<!-- find the selected Row -->
<bc4j:findRowByKey>
<bc4j:keyBinding>
<bc4j:selectionKey name="viewTable" key="key" />
</bc4j:keyBinding>
<bc4j:handlers>
<!-- remove the selected ViewObject row -->
<bc4j:removeRow />
<!-- execute the query to eliminate dead row access -->
<bc4j:executeQuery/>
</bc4j:handlers>
</bc4j:findRowByKey>
</bc4j:findViewObject>
<!-- commit the transaction, forwards to self automatically -->
<bc4j:commit/>
</bc4j:findRootAppModule>
</event>
<event name="show">
<method class="servlet.showDetails" method="doHideShowEvent" />
</event>
<event name="hide">
<method class="servlet.showDetails" method="doHideShowEvent" />
</event>
</handlers>
</page>
Update View
<?xml version="1.0" encoding="windows-1252" ?>
<page xmlns="http://xmlns.oracle.com/uix/controller"
xmlns:ctrl="http://xmlns.oracle.com/uix/controller"
xmlns:ui="http://xmlns.oracle.com/uix/ui"
xmlns:bc4j="http://xmlns.oracle.com/uix/bc4j"
xmlns:html="http://www.w3.org/TR/REC-html40"
xmlns:updatepage="http://www.example.org/siriusbilling/templates">
<ctrl:head xmlns="http://www.w3.org/TR/REC-html40">
<title>Update Properties</title>
</ctrl:head>
<templates xmlns="http://xmlns.oracle.com/uix/ui">
<templateImport source="templates/SiriusBilling.uit"/>
</templates>
<bc4j:registryDef>
<bc4j:rootAppModuleDef name="PropertiesForeignKeyLink1AppModule"
definition="siriusbilling.SiriusBCModule"
releaseMode="stateful" >
<bc4j:viewObjectDef name="PropertiesDetailView" >
<bc4j:rowDef name="UpdatePropertiesDetailView" autoCreate="false" usesCurrency="true">
<bc4j:propertyKey name="key" />
</bc4j:rowDef>
</bc4j:viewObjectDef>
<!-- Display only 20 rows -->
<bc4j:viewObjectDef name="PropertyTypesView" rangeSize="20" >
<bc4j:rowDef name="UpdatePropertyTypesView" autoCreate="false">
<bc4j:propertyKey name="key" />
</bc4j:rowDef>
</bc4j:viewObjectDef>
</bc4j:rootAppModuleDef>
</bc4j:registryDef>
<ctrl:content xmlns="http://xmlns.oracle.com/uix/ui"
xmlns:data="http://xmlns.oracle.com/uix/ui">
<updatepage:siriusPageLayout>
<pageHeader>
<globalHeader selectedIndex="0">
<contents>
<link text="Update Property" />
</contents>
</globalHeader >
</pageHeader>
<contents>
<try xmlns="http://xmlns.oracle.com/uix/ui"
xmlns:data="http://xmlns.oracle.com/uix/ui" >
<catch>
<displayException />
</catch>
<contents>
<switcher childName="default">
<boundAttribute name="childName">
<if>
<comparison type="equals">
<dataObject select="key" source="ctrl:page"/>
<dataObject source="ui:null"/>
</comparison>
<fixed text="error"/>
</if>
</boundAttribute>
<case name="error">
<header text="Required page property 'Property Type' missing. Cannot display page."/>
</case>
<case name="default">
<flowLayout>
<contents>
<!-- this will contain any validation errors after form
submission -->
<messageBox automatic="true" />
<script>
<contents>
function UOMLovCallBack(lovwin, event)
var value = lovwin.returnUOMValue;
if (value!=(void 0))
document.updateForm.UnitOfMeasure.value = lovwin.returnUOMValue;
</contents>
</script>
<form name="updateForm" method="POST" >
<contents>
<!-- we cannot implicitly determine that events
will be triggered because submit buttons are
outside the form scope, so add the placeholder
explicitly -->
<formParameter name="event" />
<!-- layout the fields in two columns -->
<spacer width="10"/>
<tableLayout width="80%"
cellPadding="2"
hAlign="center">
<contents>
<bc4j:rootAppModuleScope name="PropertiesForeignKeyLink1AppModule" >
<contents>
<bc4j:viewObjectScope name="PropertiesDetailView" >
<contents>
<bc4j:rowScope name="UpdatePropertiesDetailView" >
<contents>
<bc4j:messageChoice prompt="Property Type" attrName="PropertyType" name="PropertyType">
<contents>
<bc4j:optionList voName="PropertyTypesView" attrName="PropertyType" textAttributeName="PropertyType" size="30"/>
</contents>
</bc4j:messageChoice>
<bc4j:messageInput prompt="Property Id" vAlign="left" attrName="PropertyId" size="30"/>
<bc4j:messageInput prompt="Property Name" attrName="PropertyName" size="30"/>
<bc4j:messageInput prompt="Property Description" attrName="PropertyDescription" size="30" />
<bc4j:messageLovField prompt="Unit Of Measure"
attrName="UnitOfMeasure"
name="UnitOfMeasure"
onClick="openWindow(window,
'UOMLov.uix',
'lovwin',
{width:480, height:300},
true,
'dialog',
UOMLovCallBack);
return false;" />
</contents>
</bc4j:rowScope>
</contents>
</bc4j:viewObjectScope>
</contents>
</bc4j:rootAppModuleScope>
</contents>
</tableLayout>
</contents>
</form>
</contents>
<contents>
<contentFooter>
<contents>
<html:center>
<!-- place a row of buttons below the content -->
<pageButtonBar>
<contents>
<!-- the cancel button performs a transaction rollback -->
<button text="Cancel" ctrl:event="cancel" />
<!-- the update button submits the user-entered
form data -->
<submitButton text="Update" formName="updateForm"
ctrl:event="apply" />
</contents>
</pageButtonBar>
</html:center>
</contents>
</contentFooter>
</contents>
</flowLayout>
</case>
</switcher>
</contents>
</try>
</contents>
</updatepage:siriusPageLayout>
</ctrl:content>
<handlers>
<event name="cancel" >
<!-- using the ApplicationModule causes it to be checked out from the
ApplicationPool. It is released using stateful mode. -->
<bc4j:findRootAppModule name="PropertiesForeignKeyLink1AppModule" >
<!-- rollback the current transaction -->
<bc4j:rollback/>
<!-- forward to the summary page -->
<ctrl:go name="ViewProperties" redirect="true" />
</bc4j:findRootAppModule>
</event>
<event name="apply" >
<!-- using the ApplicationModule causes it to be checked out from the
ApplicationPool. It is released using stateful mode. -->
<bc4j:findRootAppModule name="PropertiesForeignKeyLink1AppModule" >
<!-- establish the ViewObject scope -->
<bc4j:findViewObject name="PropertiesDetailView" >
<!-- find the row by key, falling back on a new default
row if the key is not found -->
<bc4j:findRow name="UpdatePropertiesDetailView" >
<!-- set each attribute explicitly -->
<bc4j:setAttribute name="PropertyId" />
<bc4j:setAttribute name="PropertyType" />
<bc4j:setAttribute name="PropertyName" />
<bc4j:setAttribute name="PropertyDescription" />
<bc4j:setAttribute name="UnitOfMeasure" />
<!-- commit the transaction -->
<bc4j:commit/>
<bc4j:executeQuery/>
<!-- forward to the summary page -->
<ctrl:go name="ViewProperties" redirect="true" />
</bc4j:findRow>
</bc4j:findViewObject>
</bc4j:findRootAppModule>
</event>
</handlers>
</page>I think the detailDisclosure state needs to be saved and retrieved from the session.
I'm not sure using a table with singleSelection inside a detail disclosure is supported. Are you doing master-detail inside of detail disclosure? Detail disclosure is not really meant for that. In jdev 10g preview we make hooking up a master-detail easy. Here's a link to some doc about it.
http://otn.oracle.com/products/jdev/collateral/tutorials/9050/adfuix_tut.html#Create%20a%20Master-Detail%20page -
Performance Problem with Master-Detail Views
Hi,
I have developed a JSP-Applikcation with the master-detail views.
I would like to report a bad performance at fetching data records from the detail view, because all records
from master view have firstly to be retrieved to locate right row (rangesize="-1"). The number of records in
the master table ist 2500 and 7000 in detail table.
============= Code Snippets (See HOWTO:Navigate using Data Tags of J. Oropeza) =====
<jbo:DataSource id="dsMaster appid=testAppId viewobject="MaterView" rangesize="-1">
<jbo:RefreshDataSource datasource="dsMaster">
<jbo:Row id="msRow" datasource="dsMaster" action="Find" rowkeyparam="RowkeyValue">
<jbo:dataSource id="dsDetail" appid="testAppId viewobject="DetailView">
======================================================================
When rangesize="20" sets, performance is good, but the right row location of master view ist not found if the row
is not positoned in this range (No data from detail view object are displayed).
How can I improve the performance?
Many thanks for your help.
regards,
YooSung:
Thank you for your suggestion.
According to your suggestion I have changed my BC4J/JSP-application. However, the performance ist still bad.Whenn I click on a row retrieved from the master view, it takes 15 seconds until the associated data in detail view will be displayed on the other window (The application has been deployed on the test system of ISP).
In an other case with much less data (162 master and 228 detail rows), it takes only 2 seconds (The application
goes with the local server and DB of our company).
======================== master.jsp =================================
<jbo:DataSource id="dsMaster appid=testAppId viewobject="MaterView" >
<a href="detail.jsp?RowKeyValue=<jbo:ShowValue datasource="dsMaster" dataitem="RowKey"/>">
Here Click
</a>
======================== detail.jsp ======================================
<jbo:DataSource id="dsMaster appid=testAppId viewobject="MaterView">
<jbo:RefreshDataSource datasource="dsMaster">
<jbo:Row id="msRow" datasource="dsMaster" action="Find" rowkeyparam="RowkeyValue">
<jbo:dataSource id="dsDetail" appid="testAppId viewobject="DetailView">
How do you think of this coding (My application is based on the document How to of J. Oropeza)?
How can I increase the performance independently of the number of rows?
Many thanks for your help.
regards,
Yoo
Maybe you are looking for
-
Can't get icloud to sync bookmarks from pc to pc in internet explorer
i use multiple pc's (work, home, etc.) and have set up the icloud ctl pnl on each of them. my main pc (work) will sync the bookmarks with my phone and one other pc in my garage. however, i use an alien laptop in my home and cannot get the bookmarks
-
Lightroom on a Mac and PC?
I've been evaluating Lightroom on my Windows XP PC. I've been using too many tools to process and index my Nikon NEF files. I like what I see from Lightorrom. I'm in the market for a notebook to take on the road with me for jobs. I'm stuck between
-
Inplace unicode conversion - error during import in step 2
Hi, We are having problems when running the unicode conversion import in step 2: Load Kernel Library. The problem occurs when SAPINST runs the FIXR3OWNS program. We can run FIXR3OWNS manually when logged in with QSECOFR. From the sapinst_dev.log file
-
No puedo crear JCo Destination - (Can't create JCo Destination)
Amigos, Cuando intento crear la conexion aparece el siguiente error Please choose another name for the new JCo destination. The defined name 'PRDjr' is used in the SLD. Espero alguien me pueda ayudar. Saludos.
-
I just need some help with figuring this out.