oracle 存储过程和触发器复制数据

来源:asp之家 时间:2009-11-17 09:12:00 

一。存储过程的创建和使用

1.创建程序包,并在程序中创建存储过程

create or replace 
PACKAGE NCS_ICP_TJ AS 
/*lfx@ncs-cyber.com.cn*/ 
/* TODO 在此输入程序包声明 (类型, 异常错误, 方法等) */ 
/*根据备案主体ID拷贝通过表备案数据到备案临时表,拷贝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.创建程序包包体,并在程序中创建存储过程实现

create or replace 
PACKAGE BODY ncs_icp_tj AS 
/*根据备案主体ID拷贝通过表备案数据到备案临时表,拷贝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; 
/*插入网站*/ 
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)

本存储过程的调用,实现了从5张通过表复制数据到5张临时表

标签:oracle,存储过程,触发器
0
投稿

猜你喜欢

  • PHP遍历目录实现方法介绍

    2023-05-25 06:31:41
  • asp文章中随机插入网站版权文字的实现代码

    2011-04-15 11:11:00
  • asp金额大小写转换完全无错版

    2007-09-26 09:38:00
  • asp如何利用当前时间生成随机函数?

    2010-01-01 15:44:00
  • sql server 锁表语句分享

    2012-02-12 15:49:20
  • 三条asp语句搞定路径

    2007-10-22 13:30:00
  • 常用ASP自定义函数集 (S.Sams)

    2010-05-27 12:24:00
  • CSS关于Border你可能会不注意的东西

    2007-10-20 13:50:00
  • SQL Server密码管理的六个危险判断

    2008-10-23 13:57:00
  • ASP链接Mysql数据库 非DSN连接的方法

    2009-03-09 18:24:00
  • ROW_NUMBER SQL Server 2005的LIMIT功能实现(ROW_NUMBER()排序函数)

    2012-06-06 20:11:21
  • asp fso删除非空目录的例子

    2008-11-26 20:03:00
  • 如何编写CSS代码才能更有效率

    2007-11-07 18:51:00
  • Sql Server “因为文件组primary已满,未能为数据库XX对象XX分配空间”问题的解决

    2010-05-16 21:27:00
  • ASP验证码的实现原理及源码

    2007-10-02 12:14:00
  • Oracle数据库安全策略分析 (三)

    2010-07-31 13:24:00
  • asp中格式化HTML函数代码 SDCMS加强版

    2011-02-20 11:18:00
  • 用javascript实现页面无刷新更新数据

    2011-08-14 07:54:08
  • 如何才能有效对抗MySQL数据库的解密高手

    2009-05-22 18:21:00
  • ASP中将Excel数据导入到Access

    2009-02-02 09:15:00
  • asp之家 网络编程 m.aspxhome.com