Unable to update multi-row

Dear all,
I create a region with this information :
select
htmldb_item.hidden(1,QRY_IDS),
htmldb_item.hidden(2,SIT_ID),
SIT_ID SIT_ID_DISPLAY,
htmldb_item.checkbox(4,used_bl,decode(used_bl,'Y','CHECKED',NULL))used_bl,
dsc
from BSF_QRY_SITES qst,
bsf_sites sit
where sit.id = qst.sit_id and
qst.qry_ids = :p30_qry_ids
When I try to create to update my checkbox information it doesn't work.
Here the process to update it.
declare
t_use_bl char(1);
begin
for i in 1..htmldb_application.g_f01.count loop
t_use_bl := 'N';
for x in 1..htmldb_application.g_f04.count loop
if htmldb_application.g_f01(i) = htmldb_application.g_f04(x) then
t_use_bl := 'Y';
end if;
end loop;
update bsf_qry_sites
set used_bl = t_use_bl
where qry_ids = htmldb_application.g_f01(i)
and sit_id = htmldb_application.g_f02(i);
end loop;
end;
I take this example in the htmldb handbook.
Can someone help me please.
Thanks in advance
Eric

Hello,
Now I receive this error message when i try to update.
ORA-01722: invalid number
Now my select is :
select
htmldb_item.hidden(1,ids) ids,
qry_ids,
"SIT_ID" SIT_ID_DISPLAY,
htmldb_item.checkbox(2,used_bl,decode(used_bl,'Y','CHECKED',NULL))used_bl
from test_eric
and my process to update is :
declare
t_use_bl varchar2(1);
begin
for i in 1..htmldb_application.g_f01.count loop
t_use_bl := 'N';
for x in 1..htmldb_application.g_f02.count loop
if htmldb_application.g_f01(i) = htmldb_application.g_f02(x) then
t_use_bl := 'Y';
end if;
end loop;
update test_eric
set used_bl = t_use_bl
where ids = htmldb_application.g_f01(i);
end loop;
end;
Why I receive this error ?
I need to solve this problem to develop a new application. If I'm not able my user will ask to develop with an other tools.
Thanks in advance for your help
Eric

Similar Messages

  • Updating Multi-Row Form Data

    Hi Folks,
    I have the following multi-row form:
    !http://img216.imageshack.us/img216/7250/screenexample.jpg!
    This is based on the following query:
    SELECT id,
           ticker,
           deal_date,
           deal_type,
           no_shares,
           price_per_share,
           commision,
           stamp_duty,
           APEX_ITEM.CHECKBOX( 1, NULL ) AS group_ind,
           trade_group_id
      FROM trades
    WHERE ticker = 'FXPO'
    ORDER BY trade_group_id,
              ticker,
              deal_dateWhen I tick the GROUP_IND Checkbox, I want only the TRADE_GROUP_ID column value to be updated in the database for the associated row. Obviously, I could tick the checkbox in multiple rows.
    My questions are:
    1. Is it possible to modify the ApplyMRU routine to do this?
    2. If not, how would I go about submitting the ID and TRADE_GROUP_ID columns to a stored proc via an array from the APEX front end?
    3. Is there a best practice solution for my reports.
    I have some layout questions aswell, but I'll post those on a separate thread once the main functionality is working.
    Cheers.
    James

    James,
    You have access to the checked IDs using the apex_application.g_f01 array. You can pass it to your pl/sql ie:
    procedure test(p_arr in vc_arr2)
    begin
    for in in 1..p_arr.count
    loop dbms_output.put_line(p_arr(i));
    end loop;
    end;
    now you can just call your procedure with a process test(apex_application.g_f01);

  • 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.

  • 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 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".

  • 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

  • Need to perform multi-row update/delete

    Gday,
    I have a request to have one update button for a multi-row form. Also needed will be a checkbox as part of the row.
    The check boxes only purpose is to signify the record should be deleted. Thus I am assuming I cannot use default
    apex functionality and must manually build the multi-row form. I guess I would loop through and check to see if a
    record is checked delete otherwise loop through and update all columns for that record? I am assuming I should
    use the examples in http://www.oracle.com/technology/products/database/application_express/howtos/tabular_form.html
    is that all still valid for apex 3.2.1?
    Cheers

    Hello:
    You could also do the following
    Generate the tabular form page using the wizard
    Delete or not display the 'Delete' button
    Delete or not execute the 'ApplyMRD' process
    Create a new page process with a sequence higher than the standard MRU processes. Make this process conditional on the 'Submit' button. Use code similar to the one below for this page processfor i in 1..apex_application.g_f01.count loop   --- f01 is the selector checbox, f02 is the hidden column with the table's PK
      delete from emp where empno=apex_application.g_f02(apex_application.g_f01(i));
    end loop;Now, when you click 'Submit' records with their selector checkbox checked will be deleted by the newly added page process. The rest of the functionality of the tabular form remains the same.
    varad

  • Multi-master replication and replica_update_ruv: unable to update

    I'm running Sun ONE 5.2 DS on Solaris 8 with multi-master replication comprising of 2 masters (M1 & M2) and 2 consumer replicas (R1 & R2).
    M1 sends updates to consumers R1 and R2, M2 sends updates to R2 and R1 (and offcourse M1 to M2 and M2 to M1).
    Replication works well at all times. However, occasionally there are a few annoying messages in the consumers' error log files (which do not affect the replication):
    INFORMATION - NSMMReplicationPlugin - conn=-1 op=-1 msgId=-1 - csnplCommit: can't find csn 4054e7710
    000ffff0000
    INFORMATION - NSMMReplicationPlugin - conn=-1 op=-1 msgId=-1 - ruv_update_ruv: cannot commit csn 405
    4e7710000ffff0000
    INFORMATION - NSMMReplicationPlugin - conn=-1 op=-1 msgId=-1 - replica_update_ruv: unable to update
    RUV for replica o=asx.com.au, csn = 4054e7710000ffff0000
    Has anyone come across this scenario? The explanation that I found on the web refers to 4.x Master and 5.1 DS but I do not have any of that and "Allow replicas to be 4.x compatible" is not set.
    Below is the extract from "Release Notes for iPlanet Directory Server 5.1 Service Pack 1" found on the web:
    "In a topology, where an iPlanet Directory Server 5.1 Service Pack 1 is a Dedicated consumer of a 4.x directory server supplier (4665571), messages of the following type will be written to the error log:
    NSMMReplicationPlugin - csnplCommit: can't find csn 3d0f496f0001ffff0000
    NSMMReplicationPlugin - ruv_update_ruv: cannot commit csn 3d0f496f0001ffff0000
    NSMMReplicationPlugin - replica_update_ruv: unable to update RUV for replica <suffix> csn = 3d0f496f0001ffff0000
    To prevent such a situation from occuring, configure the iPlanet Directory Server 5.1 Service Pack 1 instance as a Single Master (because a 5.x master may also be a consumer)."
    Thanks in advance,
    Erika

    I have had a similar problem. and it was due to that I recreated a new replication agreement which pointed to a different server with the same id. Or to the same server with a different ID.
    The solution provided by sun was to remove the reference to the old replicas in the dse.ldif and restart but it didn't work out. not even by ldapmodify on the replicas dn.
    I had to reinstall...

  • How to re-query changed record in multi-row block after update in a called form

    Hi,
    I have a form that I use to perform searches, which is a multi-record block.
    The user can navigate to a record, press a button on call another form which provides
    more detail, and allows update of the record.
    If the user changes it, and returns to the original search form, how can I re-query the
    changed record to update the fields on the search form.
    Is there a way other than to re-query the
    whole block - a built-in to just update on record if it's changed on the database.
    If not, can I use globals to pass back the data (since only a few fields are updatable),
    and change the record without effecting its forms status.
    Many thanks
    Bernie

    BD,
    I haven't managed to look at a solution yet, but the block is a large multi-row block,
    with an ORDER BY, and since it can return a large number of records, there is a short
    delay. I was hoping there was a way of just
    re-querying the one record, which was displayed
    in the second form for update.
    I'll give the query a go, or might try and pass back some globals with the update values.
    By the way, DML Return Value is an excellent feature, but only works against Oracle 8.
    It basiclly adds the RETURNING clause to any DML statement (see SQL manual), so that if
    a trigger changes/adds values you didn't provide, it will return them back to you
    so the values in your form are correct.
    I use a trigger on the DB to populate history fields (create/update,who/when) and
    the PK sequence. Using this feature, those values are returned to the block and displayed.
    Regards
    Bernie

  • 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 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.

  • 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 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}

Maybe you are looking for

  • Sort columns in matrix report

    Hi all I create matrix report( in version 9i) I want sort columns of report when i use order by it sort rows but i want sort columns my query is like this: SELECT Code, name, DECODE(cons_code, '1', 'A', '2', 'B', '3','C', '4', 'D', '5', 'E') Activity

  • New Apple TV and iPlayer

    Does anyone know from the specs or demo whether it would be possible to stream iPlayer content to the new Apple TV? I know AirPlay can stream video content from a desktop computer or iPhone/iPod touch, but is this only via iTunes 10?

  • HT1420 I am having a problem trying to authorize my computer for itunes. Windows 7

    I am

  • Javafx 1.2 ready for large application?

    I try to use javafx to build a dashboard which may contain 5000 cells, I used Text, ImageView, Stack, HBox, VBox to build this component, which just like Table in HTML. I didnt notice that would be a problem in the begining, when more and more cells

  • Query 4 tables

    Hi, I am creating a conveyancing tracker.I need to select data from 4 tables. They are [list] [*]Client Details- Holds each client once [*]Buy- Is a purchase transaction links buy client id [*]Sale- Is a Saletransaction links buy client id [*]Remortg