Multiple Users - Tabular Forms - Multi Row Update.....

Greetings All,
Any comments, assistance, links, or even answers on the following situation would be much appreciated....
I have a Application Express 4.0 (Could upgrade to 4.1 if it would help this issue)
I have a wizard generated tabular form on a table, the form will show up to 600 records (rows) on a page.
Part 1:
The situation:
User 1: Opens the form and brings up latest data set.
User 2: Opens the form and brings up the latest data set.
User 1: Changes data for record 1
User 1: Hits submit. The data is saved.
User 2: Changes data for record 1
User 2: Changes data for record 2
User 2: Hits submit. The following error is produced:
Error in mru internal routine: ORA-20001: Error in MRU: row= 1, ORA-20001: ORA-20001: Current version of data in database has changed since user initiated update process. current checksum = "3EE15D666E9DBDC59D34CE4CFB3950C0", item checksum = "922DA12AE1E3D8856695745C4D2830D2"., update "<Removed> Error Unable to process update.
When this error occurs no updates get made to the table.
I understand that row 1 can not be updated, however I would like row 2 (and all other rows where there is no conflict) to be updated. I would then like to be able to highlight in the form the rows that failed to update (And reload the data in them from the DB).
Is this something I can achieve using my own MRU procedure, or in another way?
Can anyone point me to a good example, tutorial or book showing how to do this.
Thanks!

Thanks for the comments guys.
I have solved my issue in two different ways. Way one was not so clever, but worked, involving writing my own process for handling multi-row updates and would allow a user to fill in data for multiple rows (say 10) and have only the row with changed data rejected. V2 takes a very different approach, it uses Javascript, AJAX and the DOM model of the form to check when data is changed / updated by the user. Essentially, when a user enters an updateable form element, a AJAX request checks if the data has been changed. If it has, the value in the form is updated, and the color changed to blue to alert the user. When the user updates the data item, and AJAX request posts the new value to the database, where it is inserted. I had to build a bit of a framework to make this useable, and have to use dynamic sql in the database packages, but it work really well for what my users need! There are limitations (Currently it only supports date fields, text fields and drop down lists) but it works for me. It also involves traffic back and forth with the server each time a user moves the focus to a new form element, but it is a very light request and the work to do the select / updates in oracle is all based on a primary ke, so is ver quick.
Solution 1: (Would need to be made much more elegant):
1: Create a new text Item called P5_MESSAGE (To display error / success messages)
2: Create a new process:
DECLARE
l_cks wwv_flow_global.vc_arr2;
j pls_integer := 1;
vUpdatedCount number := 0;
vErrorCount number:=0;
vMessage varchar2(4000):='';
BEGIN
select wwv_flow_item.md5(firstname,lastname,age) cks
BULK COLLECT INTO
l_cks
from VA_TEST1 ;
for i in 1..l_cks.count
loop
if htmldb_application.g_fcs(i) != l_cks(i) then
-- Log error
vErrorCount:=vErrorCount+1;
vMessage:=vMessage||'Could not update row with ID:' || htmldb_application.g_f01(i) || '. This data has been updated by another user since you retrieved the data.<br>';
else
-- Do insert
vUpdatedCount:=vUpdatedCount+1;
update VA_TEST1
set
FIRSTNAME = replace(htmldb_application.g_f02(i),'%'||'null%',NULL)
,LASTNAME = replace(htmldb_application.g_f03(i),'%'||'null%',NULL)
,AGE = replace(htmldb_application.g_f04(i),'%'||'null%',NULL)
where ID = htmldb_application.g_f01(i);
end if;
end loop;
:P5_MESSAGE := vMessage;
end;
Note, this currently updates every row, even if the data is unchanged, this could be fixed by comparing the checksum of the data to be inserted with the checksum of the data in the table, if the same then no need to insert.
Solution 2:
Too complex to explain in detail here, if you need to implement this then let me know.

Similar Messages

  • Tabular form - Multi row delete error

    Apex 4.0.2
    We have a simple CRUD type of application on a bunch of tables built using Apex v1.6 that has, over the years, been upgraded to v4.0.2 and it is working mostly fine. It uses all out-of-the-box standard components, forms, classic reports, nothing too fancy. Recently one of the tabular forms started to misbehave, the multi-row-delete process raises a No Data Found error. The tabular form is based on a view with a INSTEAD OF trigger to handle the DML. Manually deleting the row in SQL*Plus works fine delete from mytab here pk_id = :pk_id but selecting the same row in Apex and clicking Delete raises the error.
    How does one go about troubleshooting & fixing this sort of thing? I tried re-saving the region in the Builder, exporting/importing the entire app, nothing. Running in Debug mode doesn't really provide any additional information, just that the MRD process failed. Tabular forms are the most frustrating, opaque component in Apex, wish they were easier to troubleshoot.
    Any ideas?

    Hello Vikas,
    >> How does one go about troubleshooting & fixing this sort of thing?
    By given us a bit more information :)
    • Is it a manual Tabular Form (using the ITEM API) or a wizard created one?
    • Are the Insert/Update operations work correctly? If not, what is the type of your PK column(s)?
    • If the problem is limited to the Delete operation, maybe the problem lies with the checkbox column. Are you sure that on page it is rendered as the f01 column?
    • As triggers are involved, can you save the PK that the trigger sees? Is it the expected value?
    • Are there any other processes that are fired before the DML process? If so, maybe the problem is with them. You can temporarily disable them and see if it change anything.
    >> Tabular forms are the most frustrating, opaque component in Apex, wish they were easier to troubleshoot
    Yes, I agree. However, I believe that 4.1 made some serious advancement where Tabular Form is concerned. Having simplified Tabular Form related Validations and Process should make things easier, and as a result, prone to less errors. Still, the main problem is that the type of error you are talking about is usually the result of metadata problems and these are indeed very hard to track.
    Regards,
    Arie.
    &diams; Please remember to mark appropriate posts as correct/helpful. For the long run, it will benefit us all.
    &diams; Author of Oracle Application Express 3.2 – The Essentials and More

  • Multi Row Update for Tabular Form

    1) I'm trying to understand how the built-in MRU works for tabular forms: While running through every row, does it check for changes before issuing an UPDATE or does it blindly UPDATE every row in the current pagination range?
    2) If I need to write my own Multi Row Update process for tabular forms, could someone give me some tips on how to do that?
    Thanks,
    Pavel

    1) It stored a checksum for each row that it renders. It calculates the checksum again before processing the rows. The UPDATE statement it issues has a predicate like where old_checksum!=new_checksumSo, it only updates the rows that have at least 1 column value that is different (causing the row checksum to be different)
    2) See the howto at http://www.oracle.com/technology/products/database/application_express/howtos/tabular_form.html

  • Multi-Row Update form with wrapped fields

    Hi,
    I have a multi-row update form with too many fields to fit on the screen without having to scroll. Is it possible to wrap the extra fields onto a 2nd line.
    So each DB record will actually span 2 srceen rows and fit nicely into my browser ??
    Thanks for any help,
    Brandon

    It is possible, but would require some serious work on the report template, to create a custom row template.
    I started to do this at http://htmldb.oracle.com/pls/otn/f?p=24317:191 but realized that it is hard work. Also, where would you show the headings for the second part of the row (split onto the next line)?
    Instead, I would use the Show/Hide columns technique (client-side scripting) to reduce the number of columns shown. Search for it on this forum. Carl and I have some good examples out there.

  • Multi Row Update Error

    Hello Everyone
    I get the following error when attempting to perform a multi row update. Is anyone able to advise what the issue is?
    Error in mru internal routine: ORA-20001: Error in MRU: row= 1, ORA-20001: ORA-20001: Current version of data in database has changed since user initiated update process. current checksum = "F71A42E70B86E7C8A14343633169264E", item checksum = "43A7146FE322237B683C4139D66E4DC5"., update "CSS_PRODUCTIVITY"."CENTREDATAASSOCIATIONS_TEST" set "MONTH" = :b1, "TM1_PREMISE_NAME" = :b2,

    hi oolite
    i can't help you with your problem
    but i have one suggestion
    i don't know whether you created your tabular form with the wizard or manually
    when you use the wizard
    i would suggest that you try to build a tabular form manully
    in fact it is a little bit more work but i think all what you have done by yourself
    is more transparent and errors should be found easier
    other suggestions take a look
    Error in mru internal routine: Error in MRU
    Error in mru internal routine
    or search for error on mru
    sorry that i can't tell you more

  • Multi row update not occuring

    I have created a tabular form using the wizard. This form will show three columns (and in addition a checkbox). I would like this form to be updateable in only certain instances. Because of that, I select the columns twice. I make one of them updateable, and the other read-only. Then I have a conditional display for the columns, so that the updateable columns are shown if a status variable in my page is 'EDIT' and the read-only columns are shown otherwise.
    The problem is that the multi row update does not occur. If I show one of the read-only columns when in the edit mode, the update is done. Also it is executed if I show one of the editable fields when the page is not in edit mode. But when I show only the editable fields in edit mode, and only the read-only fields when in read-only mode, the process is not run.
    What can I do about this? Why doesn't the multi row update occur?

    An alternative is to control the updates by controlling the buttons. Only show the submit/update button if the status on the page is "EDIT".

  • Forms Multi-row validation

    Forms Multi-row validation
    I have a requirement to show a validation error at form ‘At least one reviewer should have more than zero amount limit'. So we need identify highest amount limit entered in multiple rows, that highest amount limit should be >=1 if not show an error.
    Level Reviewer Amt limit
    1 ABC 0
    2 MNP 0
    3 XYZ 0
    In the above case I need show an error msg. I tried pre-insert. It didn’t work because built-in not supports pre-inserts.
    Pls advice the best methodology to has shown error in this kind of scenario.

    Hi,
    Create a Summary item based on Amt limit.
    Then in pre-insert check the value of summary item. If it is < 1 then, raise error .
    Regards

  • Conditional Select List in a Report maintained using a Multi Row Update

    I have a SQL Report that is maintained with a "Multi Row Update" process. One of the columns needs to be ether a "Select List" based on a named LOV or just "Text" (Read Only) based on the value in the column. I have the UI working using a case statement and apex_items in me SQL but the Report Column is not marked "Edit" and the "Multi Row Update" process just ignores changes.
    Any help would be great!

    Just curious, why is the first parameter to in third TEXT_FROM_ITEM invocation NULL instead of 20? Also check your first parameter in your ELSE. Shouldn't it be a global number as well?
    Did you try adding a hidden item to your SELECT statement? Something like:
    (case
    when CSSN.KTTR_BILL_STAT_UID = KT_UTIL_PKG.get_kttr_uid_from_ref_val('SESSION_BILL_STAT','SESSION_BILL_STAT_1') then
    apex_item.select_list_from_lov(20,CSSN.KTTR_BILL_STAT_UID,'KTTR_SESSION_BILL_STAT_PRPR','','NO')
    when CSSN.KTTR_BILL_STAT_UID = KT_UTIL_PKG.get_kttr_uid_from_ref_val('SESSION_BILL_STAT','SESSION_BILL_STAT_2') then
    apex_item.select_list_from_lov(20,CSSN.KTTR_BILL_STAT_UID,'KTTR_SESSION_BILL_STAT_PRPR','','NO')
    when CSSN.KTTR_BILL_STAT_UID is null then
    apex_item.text_from_lov(20,'KTTR_SESSION_BILL_STAT')
    else
    apex_item.text_from_lov(20,CSSN.KTTR_BILL_STAT_UID,'KTTR_SESSION_BILL_STAT')
    end) as KTTR_BILL_STAT_DISP,
    apex_item.hidden(30,CSSN.KTTR_BILL_STAT_UID) MIRRORThen in either an Javascript onBlur event on KTTR_BILL_STAT_DISP or in a Page Process assign the value of KTTR_BILL_STAT_DISP to MIRROR.
    Mike

  • Multi Row update using pl/sql anonymous block process

    Does anyone have an example of multi row update using a pl/sql anonymous block process?
    The reason I can not use the apex mru process is that the table in questions has a five field key.
    My attempts have failed with a bad number.
    Thanks,
    Gary

    Hi Gary,
    can y<ou pls send the definition of thet table and the UPDATE sql.
    It is a littel difficult like this.
    We need more info.
    BR,
    Lutz
    =;-)

  • Multi-row updates

    Why is it necessary to include the if statement in the below multi-row update process?
    I spent a large amount of time puzzling over this.
    Thanks!
    Bill
    for i in 1..htmldb_application.g_f01.count loop
    if htmldb_application.g_f01(i) is not null then
    update my_table
    set
    column_1 = (replace(htmldb_application.g_f02(i),'%'||'null%',NULL))
    where id = htmldb_application.g_f01(i);
    end if;
    end loop;

    Hi Marc,
    Here's my query with the key items in bold. There are no null values in the g.grid field (it's the primary key). Thanks.
    Bill
    select g.GRID,
    g.FAANUM,
    '<a href="javascript:submitDate(''' || g.grid || '''); ">' ||
    decode(decode(g.date_sub_3, null, 1, null),
    1, decode(g.date_sub_4, null, '-', to_char(g.date_sub_4, 'fmMM/fmDD/YY')),
    decode(g.date_sub_4, null, decode(g.date_rec_3, null, '-',
    (30 - trunc(sysdate - g.date_rec_3))
    || '&nbsp' || decode(trunc((32 - trunc(sysdate - g.date_rec_3))/6),
    6, '<img src="#FLOW_IMAGES#greenN.gif" alt="You must submit this by: ' ||
    to_char(g.date_rec_3 + 30,'fmMM/fmDD/YY') || '">',
    5, '<img src="#FLOW_IMAGES#greenN.gif" alt="You must submit this by: ' ||
    to_char(g.date_rec_3 + 30,'fmMM/fmDD/YY') || '">',
    4, '<img src="#FLOW_IMAGES#greenN.gif" alt="You must submit this by: ' ||
    to_char(g.date_rec_3 + 30,'fmMM/fmDD/YY') || '">',
    3, '<img src="#FLOW_IMAGES#greenN.gif" alt="You must submit this by: ' ||
    to_char(g.date_rec_3 + 30,'fmMM/fmDD/YY') || '">',
    2, '<img src="#FLOW_IMAGES#yellowN.gif" alt="You must submit this by: ' ||
    to_char(g.date_rec_3 + 30,'fmMM/fmDD/YY') || '">',
    1, '<img src="#FLOW_IMAGES#redN.gif" alt="You must submit this by: ' ||
    to_char(g.date_rec_3 + 30,'fmMM/fmDD/YY') || '">',
    '<img src="#FLOW_IMAGES#past.gif" alt="You failed to submit this by: ' ||
    to_char(g.date_rec_3 + 30,'fmMM/fmDD/YY') || '">')),
    to_char(g.date_sub_4,'fmMM/fmDD/YY'))) || '</a>' "DATE_SUB",
    g.DATE_REC,
    g.REC_BY,
    g.GRIEVANT "Grievant",
    '<a href="f?p=&APP_ID.:9:' || :APP_SESSION || '::::P9_GRID:' || g.GRID || ' target="_blank">'||substr(g.topic,1,20)||'..</a>' "Topic",
    y.word,
    '<a href="f?p=&APP_ID.:9:' || :APP_SESSION || '::::P9_GRID:' || g.GRID || ' target="_blank"><img src="#FLOW_IMAGES#view2.gif" border="0"></a>' "VIEW",
    g.reply_by,
    g.natca,
    trunc(g.reply_by-sysdate + 1,0) "Days",
    g.grid "Notes",
    null "Withdraw",
    (select count(*) from gr_blob_intersect where grid = g.grid) "NumAtt",
    decode(g.article, 0, 'E', 1, 'U') "Type_2",
    '<a href="f?p=&APP_ID.:29:' || :APP_SESSION || '::::P29_GRID:' || g.GRID || ' target="_blank"><img src="#FLOW_IMAGES#xxx.gif" border="0"></a>' "VIEW/XXX",
    htmldb_item.hidden(1,g.grid) || htmldb_item.text(2,g.arb_no,6) "Arb No",
    htmldb_item.select_list_from_query(3, g.approval, 'select distinct text d, aid r from gr_approval order by aid',null,'NO') "Approval",
    htmldb_item.text(4,g.advocate,6) "Advocate",
    htmldb_item.date_popup(5,null,g.date_arb_sched,'DD-MON-YY',8) "Arb Date"
    from GRIEVANCE g, yesno y
    where y.id = nvl(g.ORAL,0)
    and g.gr_status = 4
    and (g.facility_id in (select id from gr_facility_lookup where region_id = (select f.region_id from gr_emp g, gr_facility_lookup f where upper(username) = :APP_USER and g.facility_id = f.id)) or g.facility_id = 3)
    and g.status_id = 1
    order by g.reply_by_4

  • About Multi Row Update...

    APEX support Multi Row Update, but it is only support have two or fewer columns making up the primary key. now i want to use 3 columns as primary key to update datas, i how to implement it in APEX? thanks
    · Table Owner: The schema name for the owner of the table.
    · Table Name: Enter the table name or view. MRD’s and MRU’s can only dynamically build SQL statements for a single table or view.
    · Primary Key Column: This is the first column of the primary key for the table. It is used for building the WHERE clause for the dynamic statement.
    · Second Key Column: This is the column name for the second database column making up the primary key for the table. The MRU and MRD processes can only be used for tables that have two or fewer columns making up the primary key.
    Edited by: user8016603 on 2011-3-14 上午1:51

    check {message:id=9369070}

  • More than one multi row update region on one page - how ?

    Hi.
    I have a page on which i want to use two multi row update regions ( updateable report with three buttons like new/delete/save ).
    But i do not find a setting for the MRU-Process oder "Add-New-Line" Process that lets me reference this process to a specific region.
    The problemm is, that after adding the second region to the page, the "Add-New-Line" - process only adds the new line to the second region and not to the first region anymore.
    How can i make two processes where one adds a line to region1 and the second adds to region2. Same question is with updates too. How can i say that process on updates the changes in region1 and the other process updates the changes in region2 ?
    Thanks for help.
    greetings
    bernd

    Unfortunately, the builtin MRU process supports only 1 updatable region per page.

  • How to Multi Row Update function in Manual Tabular Form

    Hi All,
    In my application I am using manual tabular form, for Update and insert i have written pl/sql process,
    but i want to make use of MULTI_ROW_UPDATE function for update and insert operations.
    How can I implement default tabular form behaviour in manual tabular form.
    I am using:
    Oracle Database 11g
    ApEx Version 4.0
    please help me, it's urgent.
    thanks
    MR

    Hi Joao,
    First Can u pl let us know your view is based on how many
    tables?
    If it is a simple view ,you can open the form in update mode
    passing a parameter to it thru a procedure or thru a url or what
    ever you feel like(form to form,etc)..I will give you an example
    on how to open the form in update mode like below..
    1.develop a form based on a simple view
    2.Call that form Thru a simple URL
    3.In the above you are opening a form with module id
    ex:1234567890 in update mode and change portal30 to suit
    accordingly..
    4.You are passing a parameter called "ABCDEF" TO "NAME" Field to
    that form for querrying..
    5.Now the form will be opened in update mode and all the fields
    are pertaining to the parameter "ABCDEF" and you can update the
    fields....
    II..Now regarding the check boxes i need to know which version
    of the portal are u using..As for as my knowledge goes (up to
    3.0.6) there are lot of bugs with the check boxes and check box
    checked value is always "yes"(if u want to insert in to the data
    base).So try not to depend on checkboxes and instead Combo is
    the right answer till oracle portal is free of bugs.
    No triggers are required for your requirement....
    Hope i have answered your problem ...If any please revert back
    with full details
    Thanks
    Vishnu Singireddy

  • Multi row update in sql Report

    Hi All,
    I had created a Updatable SQL report , and the SQL query fetches data from four table and JOIN condition also exists.
    Currently I can Update only one row at a time but what I want is to update multiple row at same time. Is this possible without TABULAR FORM ?
    Thanks
    Dikshit

    Hi
    The whole concept of a Tabular form is that it shows a table of updatable rows. These can be modified and then when the user clicks "Update" all the rows that have been changed will be updated on the base tables.
    There is no wizard to do this any other way. However there is something in APEX called htmldb collections. These are essentially virtual tables that can hold data temporarily in memory. You could consider using a form to update each record individually, then when the user clicks "Save" it writes the updated form data to an htmldb collection. The user could then click "Update All" and all the data in the htmldb collection could be updated on the base tables.
    htmldb collections are well documented in the HTMLDB Users Guide.
    I hope this helps,
    Cj

  • Multi Row Update

    I have a tabular form for multi row inserts, updates and deletes on one table.
    I have a trigger that inserts the user name and sysdate when a new line is inserted. I am trying to do the same when a line is updated, but all lines are being updated.
    Any pointers
    Gus

    Gus,
    you will need to retrieve the primary key as a hidden field in your tabular form. you then use this promary key in your update triggers where clause to restrict to the current row.

Maybe you are looking for

  • Career Prospects in SAP xMII

    Hi All, I want few suggestions from you guys. I am basically a Java Professional. I have 2 years experience in Java, and now, I have been working in SAP xMII for only 1 n half months. I find xMII very interesting. Can anybody please tell me about the

  • Dashed Line Print Problem

    I used the arch tool to create sine waves in Illustrator which are shown below. When the EPS is placed into Acrobat and the PDF is printed the ends of the dashed sine waves print as solid lines. I tried grouping each sine wave and that did not solve

  • Safari doesn't support iFrames????

    I went on the Black and Decker website to register a new tool and I was told I could not because my browser didn't recognize iFrames. I have no idea what iFrames are and why Safari doesn't work. I did get on the site using FireFox. Tried a second tim

  • HT203167 i can't find my music since I purchased a new laptop. How do I get it back with windows 8

    I have windows 8. Since I downloaded itunes all my music that I had on itunes is gone. Is there a way to recover my missing music?

  • Inner class variable access

    Hi all If for example I pass a JButton to a method or construcrtor of another Class. Is there a way to make this JButton accessable from all other methods or subclasses in that Class? It's something that has caused me problems in the past, I've been