a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 數(shù)據(jù)庫 > Oracle > 正文

oracle 存儲過程和觸發(fā)器復制數(shù)據(jù)

2024-08-29 13:53:46
字體:
來源:轉載
供稿:網(wǎng)友
一。存儲過程的創(chuàng)建和使用

1.創(chuàng)建程序包,并在程序中創(chuàng)建存儲過程

create or replace
PACKAGE NCS_ICP_TJ AS
  /*lfx@ncs-cyber.com.cn*/
  /* TODO 在此輸入程序包聲明 (類型, 異常錯誤, 方法等) */
       /*根據(jù)備案主體ID拷貝通過表備案數(shù)據(jù)到備案臨時表,拷貝5張*/
  PROCEDURE ICP_PASS_TO_TEMP(
              v_main_id IN icp_gn_temp_baxx_zt.ztid%TYPE,
               v_lyd     IN icp_gn_temp_baxx_zt.SJXT_ZTID%TYPE,
               v_in_hmd  IN icp_gn_temp_baxx_zt.in_hmd%TYPE,
               v_czlb    IN icp_gn_temp_baxx_zt.czlb%TYPE,
               v_bajd    IN icp_gn_temp_baxx_zt.bajd%TYPE
              );            
END NCS_ICP_TJ;
2.創(chuàng)建程序包包體,并在程序中創(chuàng)建存儲過程實現(xiàn)

create or replace
PACKAGE BODY ncs_icp_tj AS
   /*根據(jù)備案主體ID拷貝通過表備案數(shù)據(jù)到備案臨時表,拷貝5張*/
   PROCEDURE ICP_PASS_TO_TEMP(
               v_main_id IN icp_gn_temp_baxx_zt.ztid%TYPE,
               v_lyd     IN icp_gn_temp_baxx_zt.SJXT_ZTID%TYPE,
               v_in_hmd  IN icp_gn_temp_baxx_zt.in_hmd%TYPE,
               v_czlb    IN icp_gn_temp_baxx_zt.czlb%TYPE,
               v_bajd    IN icp_gn_temp_baxx_zt.bajd%TYPE
               )
   IS
    v_lsh integer;
   BEGIN
     select SEQ_ICP_GN_TEMP_BAXX_ZT_ZTID.NEXTVAL into v_lsh from dual;   
     IF v_main_id IS NULL OR v_lyd IS NULL OR v_in_hmd IS NULL OR v_czlb IS NULL OR v_bajd IS NULL THEN
        RAISE_application_ERROR(-20000, 'Exsit null value in arguments.');
     END IF;
     /*所有插入的查詢條件為主體ID*/
     /* 插入主體*/
       INSERT INTO ICP_GN_TEMP_BAXX_ZT
      (LSH, BBDW,ZTID,  SJXT_ZTID, YHM_ID, IN_HMD, CZLB, SCBBSJ, ZJXGSJ, DWMC, DWXZ, TZZ, ZJLX, ZJHM, SHENGID,
       SHIID, XIANID, XXDZ, ZJZS,JYLX, WZFZR, WZFZR_ZJLX, WZFZR_ZJHM, WZFZR_DHHM, WZFZR_SJHM,
       WZFZR_DZYJ, WZFZR_MSN, WZFZR_QQ, BAXH, BAJD, ZSYXQ, SHR_XM,
       SHSJ, BZ, LRYHLX, LR_YHM_ID, BAMM)
        SELECT
        v_lsh, BBDW, v_main_id, SJXT_ZTID, YHM_ID, v_in_hmd/*是否在黑名單*/, v_czlb/*操作類別*/, SCBBSJ, ZJXGSJ, DWMC, DWXZ, TZZ, ZJLX, ZJHM, SHENGID,
        SHIID, XIANID, XXDZ, ZJZS, JYLX,WZFZR, WZFZR_ZJLX, WZFZR_ZJHM, WZFZR_DHHM, WZFZR_SJHM,
        WZFZR_DZYJ, WZFZR_MSN, WZFZR_QQ, BAXH,v_bajd/*備案階段*/, ZSYXQ, SHR_XM,
        SHSJ,BZ, LRYHLX, LR_YHM_ID, BAMM
        FROM ICP_GN_BAXX_ZT WHERE ID = v_main_id;
      /*插入網(wǎng)站*/
     INSERT INTO ICP_GN_TEMP_BAXX_WZ
      (LSH,BBDW,WZID, ZTID, SJXT_WZID, SCBBSJ, XGSJ, WZMC, SYURL, WZFZR, WZFZR_ZJLX, WZFZR_ZJHM, WZFZR_DHHM, WZFZR_SJHM, WZFZR_DZYJ, WZFZR_MSN, WZFZR_QQ, NRLX, FWNR, BAXH, LRYHLX, LR_YHM_ID, BAMM, BZ,BAJD)
      SELECT
      v_lsh,BBDW,id, v_main_id, SJXT_WZID, SCBBSJ, XGSJ, WZMC, SYURL, WZFZR, WZFZR_ZJLX, WZFZR_ZJHM, WZFZR_DHHM, WZFZR_SJHM, WZFZR_DZYJ, WZFZR_MSN, WZFZR_QQ, NRLX, FWNR,  BAXH, LRYHLX, LR_YHM_ID, BAMM, BZ,1
        FROM ICP_GN_BAXX_WZ
       WHERE ZTID = v_main_id;
      /*插入接入*/
      INSERT INTO ICP_GN_TEMP_BAXX_JR
      (lsh, bbdw,JRID, ZTID, WZID, SJXT_JRID, SSISP, WZFB, WZJRFS, LRYHLX, LR_YHM_ID, BAMM, bajd)
      SELECT
       v_lsh, bbdw,ID, v_main_id, WZID, SJXT_JRID, SSISP, WZFB, WZJRFS, LRYHLX, LR_YHM_ID, BAMM,v_bajd
        FROM ICP_GN_BAXX_JR
       WHERE ZTID =v_main_id;
     /*插入ip*/
       INSERT INTO ICP_GN_TEMP_BAXX_IPLB
      (lsh,bbdw,IPID, ZTID, WZID, JRID, SJXT_IPID, QSIP, ZZIP)
      SELECT v_lsh, bbdw,ID, v_main_id, WZID, JRID, SJXT_IPID, QSIP, ZZIP
        FROM ICP_GN_BAXX_IPLB
       WHERE ZTID = v_main_id;

       /*插入域名*/
       INSERT INTO ICP_GN_TEMP_BAXX_YMLB
      (lsh, bbdw,YMID, ZTID, WZID, SJXT_YMID, YM)
      SELECT
      v_lsh, bbdw,ID, v_main_id, WZID, SJXT_YMID, YM
        FROM ICP_GN_BAXX_YMLB
       WHERE ZTID = v_main_id;

   END ICP_PASS_TO_TEMP;

END ncs_icp_tj;

3.  調用存儲過程,call ncs_icp_tj.icp_pass_to_temp(5,1,0,2,17)

本存儲過程的調用,實現(xiàn)了從5張通過表復制數(shù)據(jù)到5張臨時表

二,觸發(fā)器的創(chuàng)建。

1.行級觸發(fā)器,沒插入一條數(shù)據(jù)執(zhí)行一次, 向臨時表中加入數(shù)據(jù)時,執(zhí)行此觸發(fā)器,把臨時表插入到臨時表的數(shù)據(jù)復制的日志表中

  create or replace
TRIGGER TRIGGER_ICP_TEMP_ZT_INSERT
AFTER INSERT ON ICP_GN_TEMP_BAXX_ZT
FOR EACH ROW
BEGIN
    insert into ICP_GN_BAXX_XGLS_ZT
    (ID,LSH, BBDW,LS_ID,ZTID,SJXT_ZTID, DWMC, DWXZ, TZZ, ZJLX, ZJHM, SHENGID,
    SHIID, XIANID, XXDZ, ZJZS,JYLX, WZFZR, WZFZR_ZJLX, WZFZR_ZJHM, WZFZR_DHHM, WZFZR_SJHM,
    WZFZR_DZYJ, WZFZR_MSN, WZFZR_QQ, BAXH, SHR_XM,
    SHSJ, BZ, LRYHLX, LR_YHM_ID, BAMM)
    values( 
    SEQ_ICP_GN_BAXX_XGLS_ZT_ID.NEXTVAL,:new.LSH, :new.BBDW,:new.CZLB,:new.ZTID,:new.SJXT_ZTID, :new.DWMC, :new.DWXZ, :new.TZZ, :new.ZJLX, :new.ZJHM, :new.SHENGID,
    :new.SHIID, :new.XIANID, :new.XXDZ, :new.ZJZS,:new.JYLX, :new.WZFZR, :new.WZFZR_ZJLX, :new.WZFZR_ZJHM, :new.WZFZR_DHHM, :new.WZFZR_SJHM,
    :new.WZFZR_DZYJ, :new.WZFZR_MSN, :new.WZFZR_QQ, :new.BAXH, :new.SHR_XM,
    :new.SHSJ, :new.BZ, :new.LRYHLX, :new.LR_YHM_ID, :new.BAMM);
END;


create or replace TRIGGER TRIGGER_ICP_TEMP_WZ_INSERT
AFTER INSERT ON ICP_GN_TEMP_BAXX_WZ
FOR EACH ROW
BEGIN
    insert into ICP_GN_BAXX_XGLS_WZ
    (ID,
    LSH,BBDW,WZID, ZTID, SJXT_WZID, WZMC, SYURL,WZFZR, WZFZR_ZJLX, WZFZR_ZJHM, WZFZR_DHHM,
    WZFZR_SJHM, WZFZR_DZYJ, WZFZR_MSN, WZFZR_QQ, NRLX, FWNR, BAXH, LRYHLX, LR_YHM_ID,BZ, ls_id)
    values( SEQ_ICP_GN_BAXX_XGLS_WZ_ID.NEXTVAL,
    :new.LSH,:new.BBDW,:new.WZID, :new.ZTID, :new.SJXT_WZID,  :new.WZMC, :new.SYURL,:new.WZFZR, :new.WZFZR_ZJLX, :new.WZFZR_ZJHM, :new.WZFZR_DHHM,
    :new.WZFZR_SJHM, :new.WZFZR_DZYJ, :new.WZFZR_MSN, :new.WZFZR_QQ, :new.NRLX, :new.FWNR, :new.BAXH, :new.LRYHLX, :new.LR_YHM_ID,:new.BZ,1);
END;


create or replace
TRIGGER TRIGGER_ICP_TEMP_JR_INSERT
AFTER INSERT ON ICP_GN_TEMP_BAXX_JR
FOR EACH ROW
BEGIN
    insert into ICP_GN_BAXX_XGLS_JR
    (ID,
    lsh, bbdw,JRID, ZTID, WZID, SJXT_JRID, SSISP,
    WZFB, WZJRFS, LRYHLX, LR_YHM_ID, ls_id
    )
    values (SEQ_ICP_GN_BAXX_XGLS_JR_ID.NEXTVAL,
    :new.lsh, :new.bbdw,:new.JRID, :new.ZTID, :new.WZID, :new.SJXT_JRID, :new.SSISP,
    :new.WZFB, :new.WZJRFS, :new.LRYHLX, :new.LR_YHM_ID,1);
END;


create or replace
TRIGGER TRIGGER_ICP_TEMP_IPLB_INSERT
AFTER INSERT ON ICP_GN_TEMP_BAXX_IPLB
FOR EACH ROW
BEGIN
    insert into ICP_GN_BAXX_XGLS_IPLB
    (ID,
     lsh,bbdw,IPID, ZTID, WZID, JRID, SJXT_IPID, QSIP, ZZIP, ls_id
    )
   values( SEQ_ICP_GN_BAXX_XGLS_IPLB_ID.NEXTVAL,
     :new.lsh,:new.bbdw,:new.IPID, :new.ZTID, :new.WZID, :new.JRID, :new.SJXT_IPID, :new.QSIP, :new.ZZIP,1);
END;

2.表級觸發(fā)器 插入整個過程中,觸發(fā)器只之行一次 ,當向AAA表中如入一條數(shù)據(jù),將真?zhèn)€AAA表的數(shù)據(jù)復制BBB表

create or replace
TRIGGER TRIGGER_AAA_INSERT
AFTER INSERT ON AAA
BEGIN
    insert into BBB(userid, username)
    select id, username from AAA;
END;
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 高清国产一区二区三区四区五区 | 欧美日韩免费一区 | 国产精品永久免费 | 青青青青在线 | 日本一级中文字幕久久久久久 | 中文字幕免费看 | 婷婷色播婷婷 | 亚洲综合99| 国产精品欧美一区二区三区 | 国产精品一区二区精品 | 日本免费成人 | 国产美女在线精品免费观看网址 | 国产欧美精品一区二区三区四区 | www久久久| 日本欧美国产 | 青青草91青娱盛宴国产 | 国产精品多久久久久久情趣酒店 | 午夜精品久久久久久久久久久久久 | 免费99精品国产自在在线 | 日本福利一区二区 | 中文字幕日韩欧美一区二区三区 | 久久亚洲美女视频 | 久久国产欧美一区二区三区精品 | 毛片一区 | av男人天堂网 | 一级日韩电影 | 国产美女高潮一区二区三区 | 久久国产精品一区二区 | 色综合一区 | 国产片在线观看 | av中文字幕在线播放 | 一级黄色片欧美 | 三级av在线 | 91在线精品一区二区 | 国产综合久久久 | 国产精品大全 | 天天插天天操天天干 | 国产免费自拍视频 | 国产午夜精品一区二区三区 | 精品久久久久久久久久久久久久 | 欧美日韩成人在线 |