帮我写个触发器

ptma 2008-04-17 10:47:21
表 A 字段 Group_ID , Member_CNT
表 B 字段 Group_ID , Member_ID

要求当 B 改变时 (Insert,update,delete)触发

触发器要实现的效果: 根据 select count(*) from B where Group_ID=??? 来更新 A 表中的 Member_CNT
...全文
77 8 打赏 收藏 举报
写回复
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
ptma 2008-04-22
  • 打赏
  • 举报
回复
我不要整表更新

这样的话 , 没有一个是对的

[Quote=引用 7 楼 alarmiss 的回复:]
......
[/Quote]

表 B 上的行级触发器是不能在对 B 进行任何操作的.

---------------------------------------------------
求人不如求己 , 自己搞定了

create or replace trigger Member_COUNT
after insert or update or delete on B
for each row
begin
if inserting then
--如果是插入
update A set Member_CNT=Member_CNT + 1 where Group_ID=:new.Group_ID;
elsif updating then
--如果是更新
update A set Member_CNT=Member_CNT + 1 where Group_ID=:new.Group_ID;
update A set Member_CNT=Member_CNT - 1 where Group_ID=:old.Group_ID;
elsif deleting then
--如果是删除
update A set Member_CNT=Member_CNT - 1 where Group_ID=:old.Group_ID;
end if;
end Member_COUNT;
alarmiss 2008-04-17
  • 打赏
  • 举报
回复

create or replace trigger t_a_b
after insert or update or delete on B
for each row
declare
flag number;
begin
select count(*) into flag from A where group_id=:new.group_id;
if flag=0 then
insert into A values(:new.group_id,1);
else
update A a set a.member_cnt=a.member_cnt-1
where a.group_id=:old.group_id;
updata A a set a.member_cnt=a.menber_cnt+1
where a.group_id=:new.group_id;
end if;
commit;
end;


没法连数据库了,不能测试,不过思路是这样滴:
如果insert的是新的group,就在A中插入新的记录,并设置cnt为1;
如果insert的不是原有的group,或者是update和delete操作,
把原group的cnt-1,把新group的cnt+1;

这种写法是我假想了楼主的业务逻辑,这样可以解决6楼说数据量大的问题;
但是如果楼主的业务逻辑跟我假想的不同,那么这样写就有问题,
那么就把update部分改为:


update A a set a.member_cnt=(select count(*) from B where group_id=:old.group_id)
where a.group_id=:old.group_id;
updata A a set a.member_cnt=( select count(*) from B where group_id=:new.group_id)
where a.group_id=:new.group_id;
yaiger 2008-04-17
  • 打赏
  • 举报
回复
B表里面有多少数据?数据量大的话性能很低啊
ehsgs 2008-04-17
  • 打赏
  • 举报
回复
楼上你真太厉害了

关注你狠久了 狠厉害
HelloWorld_001 2008-04-17
  • 打赏
  • 举报
回复
zhu_gx ,你这样是接不到分的。还是认真回答点问题接分把
ehsgs 2008-04-17
  • 打赏
  • 举报
回复
如果b表中的count数是通过和a表中的group_ID关联取得的话可以这样写
CREATE OR REPLACE TRIGGER AAAA
BEFORE INSERT OR DELETE OR UPDATE
ON B
REFERENCING OLD AS OLD NEW AS NEW
BEGIN
update A a set a.Member_CNT = (select count(*) from B where Group_id = a.Group_id)
END;
/
zhu_gx 2008-04-17
  • 打赏
  • 举报
回复
低调拼小命接分,帮顶。。。。。。
ehsgs 2008-04-17
  • 打赏
  • 举报
回复
CREATE OR REPLACE TRIGGER AAAA
BEFORE INSERT OR DELETE OR UPDATE
ON B
REFERENCING OLD AS OLD NEW AS NEW
BEGIN
update A a set a.Member_CNT = (select count(*) from B where Group_id = ???)
END;
/
发帖
非技术区

1617

社区成员

Oracle 非技术区
社区管理员
  • 非技术区社区
加入社区
帖子事件
创建了帖子
2008-04-17 10:47
社区公告
暂无公告