[ 
https://issues.apache.org/jira/browse/DERBY-6383?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=13805083#comment-13805083
 ] 

Mamta A. Satoor commented on DERBY-6383:
----------------------------------------

I will have a patch ready by tomorrow. I found that this issue is for statement 
triggers. Row triggers work fine. For the reproduction ij script  provided by 
Knut, if we add a row level trigger as shown below, it will cause the row 
trigger to fire only when we update the column on which row trigger is defined.

create trigger t2 after update of x on t1 referencing old as old_row for each 
row insert into t2 values(old_row.x, old_row.y);
update t1 set y = y + 1;
select count(*) from t2;
update t1 set x = x + 1;
select count(*) from t2;


> Update trigger defined on one column fires on update of other columns
> ---------------------------------------------------------------------
>
>                 Key: DERBY-6383
>                 URL: https://issues.apache.org/jira/browse/DERBY-6383
>             Project: Derby
>          Issue Type: Bug
>          Components: SQL
>    Affects Versions: 10.7.1.4, 10.8.1.2, 10.9.1.0, 10.10.1.1
>            Reporter: Knut Anders Hatlen
>            Assignee: Mamta A. Satoor
>         Attachments: d6383.sql
>
>
> I see this problem on 10.8 and higher. To reproduce, create a database with a 
> trigger like this:
> connect 'jdbc:derby:trigdb;create=true';
> create table t1(x int, y int);
> create table t2(x int, y int);
> create trigger tr after update of x on t1 referencing old table as old insert 
> into t2 select * from old;
> Then run dblook on the database, and you'll see the following output:
> -- ----------------------------------------------
> -- DDL Statements for triggers
> -- ----------------------------------------------
> CREATE TRIGGER "APP"."TR" AFTER UPDATE OF "X", "Y" ON "APP"."T1" REFERENCING 
> OLD_TABLE AS OLD FOR EACH STATEMENT insert into t2 select * from old;
> Notice that the DDL creates an update trigger for columns X and Y, whereas 
> the original trigger was defined on column X only.
> I see the expected DDL on 10.7.1.1.



--
This message was sent by Atlassian JIRA
(v6.1#6144)

Reply via email to