今天遇到个奇怪的事情,写了个触发器,但是总是说是编译但有错误,刷新的时候,触发器报错。停用的时候也停用不了,对触发的表也不能插入数据,看了大半天原来是其中一条语句写错了,结合需求总结出了一点东西:
1、触发器命名要规范,尽量都用大写,如果其中有大写也有小写,则触发器报错不会明确提示哪错了(PS:这是自己遇到的)
上图的命名规则是不规范的
应该命名为:
2、需求
在一个有两千多万条记录的表中统计数量
应用场景
查询签发电子社保卡的人数,根据地区,签发渠道以及时间统计
需求实现分析:
(1)添加索引,在需要查询条件中添加索引,以提高速度
(2)建立统计表,通过定时任何或触发器生成汇总表,需要查询数据的时候直接查询统计表即可(本人通过此方式实现)
(3)建立表分区,根据地区、渠道等建立分区。
建立表分区的方式的确可以加快速度,但是也有一些问题,比如分区后的数据项不能修改等等。
3、实现方案
//通过触发器的方式建立汇总表
CREATE OR REPLACE TRIGGER "TR_ESSC_USER_INSERT"
AFTER INSERT ON essc_user FOR EACH ROW
DECLARE
sign_amount number:=0;
glob_count number:=0;
glob_count2 number:=0;
BEGIN
select count(aab301) into glob_count from essc_user_summary where aab301=:new.aab301 and channel_no=:new.channel_no
and sign_date=:new.sign_date;
if glob_count>0 then
select sign_amount into glob_count2 from essc_user_summary where aab301=:new.aab301 and channel_no=:new.channel_no
and sign_date=:new.sign_date;
glob_count2:=glob_count2+1;
update essc_user_summary set sign_amount=glob_count2 where aab301=:new.aab301 and channel_no=:new.channel_no
and sign_date=:new.sign_date;
--commit;
else
insert into essc_user_summary
(aab301, sign_amount, channel_no, sign_date)
values
(:new.aab301, 1, :new.channel_no, :new.sign_date);
--commit;
end if;
END;