如何防止大的DML语句?

开发人员在开发库上更新某个表的记录时总忘了添加限制(Where)条件, 而错误地更新了数据, 几个小时或几天后来求助DBA, 给DBA制造了不少麻烦, 有没有办法限制他们一句话能更新的记录的条数呢? 下面的方法可以用来限制一条语句能更新的记录数, 首先来创建一个包.

create or replace package temppkg as
rowcount number := 0;
end;
/

创建一个语句级(执行前)的触发器, 初始化包中的变量.

create or replace trigger trg_before_update_NOTEINFO
before update on NOTEINFO
begin
temppkg.rowcount := 0;
end;
/

创建一个行级的触发器, 进行计数和检查, 并抛出错误.

create or replace trigger trg_update_NOTEINFO_row
before update on NOTEINFO
for each row
begin
temppkg.rowcount := temppkg.rowcount + 1;
if temppkg.rowcount > 100 then
temppkg.rowcount := 0;
raise_application_error(-20002,'error message ...');
end if;
end;
/

这个办法是不是太土了? 用这个方法, 有点看不起自已.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值