Oracle觸發器查詢統計本表

來源:互聯網
上載者:User

Oracle觸發器查詢統計本表

這次由於項目需要,實際動手演練了一把,達到了需要的效果,大致是插入資料後,統計表內和當前插入資料時間相同的個數。

採用行級觸發器+語句級觸發器。

--包

  CREATE OR REPLACE PACKAGE UPDATECASE AS
  TYPE T_DATE IS TABLE OF date INDEX BY BINARY_INTEGER;
  V_UPDATETIME T_DATE;
  V_ROW  BINARY_INTEGER := 0;
  end;

--行級觸發器

  create or replace trigger Tri_student_row
  after insert or update or delete
  on student
  FOR EACH ROW
BEGIN
  updatecase.V_ROW  :=  updatecase.V_ROW + 1;
  if DELETING  then
    updatecase.V_UPDATETIME(updatecase.V_ROW) := :OLD.CREATETIME;
  else
  updatecase.V_UPDATETIME(updatecase.V_ROW) := :NEW.CREATETIME;
  end if;
END;

--語句級觸發器

create or replace trigger Tri_student
  after insert or update or delete on student
declare
  studentcount number(38,5);
BEGIN
  FOR V_LOOP IN 1 .. UPDATECASE.V_ROW LOOP
    select count(*)
      into studentcount from student t
    where t.createtime = UPDATECASE.V_UPDATETIME(V_LOOP);
    insert into personcount(comedate,count)values(UPDATECASE.V_UPDATETIME(V_LOOP),studentcount);
  end loop;
  UPDATECASE.V_ROW := 0;
END;

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.