What does "#now do something with newreorderrow" do? 

On Thursday, 12 June 2014 14:12:45 UTC-5, Chris Farrar wrote:
>
> Hi,
>
> I'm struggling with a strange issue.
>
> I have a web2py application with a simple data model.  I have a table 
> called "reorder".  The user is able to interact with "reorder" using a 
> SQLFORM.grid.   I have implemented the oncreate call back.  My oncreate 
> callback gets the id of the newly inserted reorder record then does 
> something with it.
>
>
> def oncreatereorderhandler(form):
>     myid = form.vars.id
>     newreorderrow = db.reorder(myid)
>     #now do something with newreorderrow
>
>
> Generally this works well.  form.vars.id correctly corresponds to the id 
> of the newly inserted row and life is happy.  The problem occurs when I put 
> a database trigger on the reorder table that fires after the insert. 
>  Whenever this trigger is on the database the value of form.vars.id is 
> nonsense.  The actual id of the inserted row is fine it's just that the 
> value of form.vars.id in now way corresponds to it.  For example, after 
> the trigger is added, the values of form.vars.id will be 4 for the very 
> next insert.  For every insert after the value will increment by 3 (eg 4, 
> 7, 10, 13, etc).  When I remove the trigger everything returns to normal.  
>
> How is form.vars.id populated and how would a DB trigger interfere?
>
> Here's the trigger and associated procedure.   It was generated by 
> symmetricds.
>
> CREATE TRIGGER sym_on_i_for_rrdr_trggr_crp
>   AFTER INSERT
>   ON reorder
>   FOR EACH ROW
>   EXECUTE PROCEDURE fsym_on_i_for_rrdr_trggr_crp();
>
>
> -- Function: fsym_on_i_for_rrdr_trggr_crp()
>
> -- DROP FUNCTION fsym_on_i_for_rrdr_trggr_crp();
>
> CREATE OR REPLACE FUNCTION fsym_on_i_for_rrdr_trggr_crp()
>   RETURNS trigger AS
> $BODY$                                                                     
>                                                                           
>  begin                                                                     
>                                                                             
>                                                    if 1=1 and 
> "public".sym_triggers_disabled() = 0 then                                   
>                                                                             
>                       insert into "public".sym_data                         
>                                                                             
>                                                     (table_name, 
> event_type, trigger_hist_id, row_data, channel_id, transaction_id, 
> source_node_id, external_data, create_time)                                 
>                                            values(                         
>                                                                             
>                                                                             
>                  'reorder',                                                 
>                                                                             
>                                                      'I',                   
>                                                                             
>                                                                             
>                         8,                                                 
>                                                                             
>                                                       
>           case when new."uuid" is null then '' else '"' || 
> replace(replace(cast(new."uuid" as varchar),$$\$$,$$\\$$),'"',$$\"$$) || 
> '"' end||','||
>           case when new."id" is null then '' else '"' || 
> cast(cast(new."id" as numeric) as varchar) || '"' end||','||
>           case when new."modified_on" is null then '' else '"' || 
> to_char(new."modified_on", 'YYYY-MM-DD HH24:MI:SS.US') || '"' end||','||
>           case when new."productid" is null then '' else '"' || 
> replace(replace(cast(new."productid" as varchar),$$\$$,$$\\$$),'"',$$\"$$) 
> || '"' end||','||
>           case when new."reorderquantity" is null then '' else '"' || 
> cast(cast(new."reorderquantity" as numeric) as varchar) || '"' end||','||
>           case when new."receivedquantity" is null then '' else '"' || 
> cast(cast(new."receivedquantity" as numeric) as varchar) || '"' end||','||
>           case when new."reorderdate" is null then '' else '"' || 
> to_char(new."reorderdate", 'YYYY-MM-DD HH24:MI:SS.US') || '"' end||','||
>           case when new."expectedreceivedate" is null then '' else '"' || 
> to_char(new."expectedreceivedate", 'YYYY-MM-DD HH24:MI:SS.US') || '"' 
> end||','||
>           case when new."vendorso" is null then '' else '"' || 
> replace(replace(cast(new."vendorso" as varchar),$$\$$,$$\\$$),'"',$$\"$$) 
> || '"' end||','||
>           case when new."customerpo" is null then '' else '"' || 
> replace(replace(cast(new."customerpo" as varchar),$$\$$,$$\\$$),'"',$$\"$$) 
> || '"' end||','||
>           case when new."edigenerated" is null then '' else '"' || 
> replace(replace(cast(new."edigenerated" as 
> varchar),$$\$$,$$\\$$),'"',$$\"$$) || '"' end||','||
>           case when new."active" is null then '' else '"' || 
> replace(replace(cast(new."active" as varchar),$$\$$,$$\\$$),'"',$$\"$$) || 
> '"' end,                                                                   
>                                                                             
>                                              'sschannel',                   
>                                                                             
>                                                                             
>            txid_current(),                                                 
>                                                                             
>                                                         
> "public".sym_node_disabled(),                                               
>                                                                             
>                               null,                                         
>                                                                             
>                                                                 
> CURRENT_TIMESTAMP                                                           
>                                                                             
>                                              );                             
>                                                                             
>                                                                             
>               end if;                                                       
>                                                                             
>                                                                             
>                                                                             
>                                                                             
>         return null;                                                       
>                                                                             
>                                                       end;                 
>                                                                             
>                                                                             
>                           $BODY$
>   LANGUAGE plpgsql VOLATILE
>   COST 100;
> ALTER FUNCTION fsym_on_i_for_rrdr_trggr_crp()
>   OWNER TO tom;
>
>

-- 
Resources:
- http://web2py.com
- http://web2py.com/book (Documentation)
- http://github.com/web2py/web2py (Source code)
- https://code.google.com/p/web2py/issues/list (Report Issues)
--- 
You received this message because you are subscribed to the Google Groups 
"web2py-users" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to web2py+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to