如何防止大的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;
/

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

留言 (2)

怎么觉得eBay的软件开发管理还停留在比较原始的阶段,CMM2有吗?

只是开发库上的,可能不是很看重吧,管理再好,不同水平的人多了后,也难避免的。

发表留言:

« Previous | Main | Next »

英语900句 | English 900

  • I stayed and did some extra work.
  • 我留下加了一会儿班.
  • The TV programs were really boring, so I went to bed very early.
  • 电视节目很无聊, 所以我早早睡了.
  • I read a magazine in bed.
  • 我躺在床上看杂志.
  • I didn't sleep well.
  • 我没睡好.
  • I slept soundly all night.
  • 我整夜睡的很熟.