这篇文章主要介绍了Oracle中多表关联批量插入,批量更新与批量删除操作,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下

该文章会分为三部分

1.多表关联批量插入

2.多表关联批量更新

3.多表关联批量删除

首先要明白一点,为什么会有批量这一个概念,无非就是数据太多了,在java端把数据查出来然后在按照100-300的批次进行更新太耗性能了,而且写出来的代码会非常的臃肿,所谓好的实现是用最少的,最精简的代码实现需求,代码越少,留给自己犯错误的机会更少。

还有一个知识点就是多表关联,对于查询肯定是可以多表关联的,其实对于除了查询之外也是可以进行多表关联过滤数据的,从而达到在Oracle中查到目标数据即可更新,从而规避规避以往需要单独查一次数据然后在按照100-300的批次做插入,更新,删除的操作 。

创建必须的表和序列语句:

--创建部门表 dept:
CREATE TABLE dept
(
 deptno NUMBER(2) CONSTRAINT PK_DEPT PRIMARY KEY,
 dname VARCHAR2(14) ,
 loc VARCHAR2(13) , 
 CREATEDTIME DATE, 
 UPDATEDTIME DATE, 
 CREATEDBY NUMBER(7,0), 
 UPDATEDBY NUMBER(7,0)
) ;

--创建员工表 emp:
CREATE TABLE emp
(  empno NUMBER(4) CONSTRAINT PK_EMP PRIMARY KEY,
  ename VARCHAR2(10),
  job VARCHAR2(15),
  mgr NUMBER(4),
  hiredate DATE,
  sal NUMBER(7,2),
  comm NUMBER(7,2),
  deptno NUMBER(2) CONSTRAINT FK_DEPTNO REFERENCES DEPT, 
  CREATEDTIME DATE, 
  UPDATEDTIME DATE, 
  CREATEDBY NUMBER(7,0), 
  UPDATEDBY NUMBER(7,0)
);

--创建员工表 emp_copy:
CREATE TABLE emp_copy
(  empno NUMBER(4),
  ename VARCHAR2(10),
  job VARCHAR2(15),
  mgr NUMBER(4),
  hiredate DATE,
  sal NUMBER(7,2),
  comm NUMBER(7,2),
  deptno NUMBER(2), 
  CREATEDTIME DATE, 
  UPDATEDTIME DATE, 
  CREATEDBY NUMBER(7,0), 
  UPDATEDBY NUMBER(7,0)
 );
--自定义一个序列 
 create sequence emp_sequence
    increment by 1 --每次增加几个,我这里是每次增加1 
    start with 1  --从1开始计数 
    nomaxvalue   --不设置最大值 
    nocycle     --一直累加,不循环 
    nocache    --不建缓冲区 

--插入dept表数据:
INSERT INTO dept VALUES(10,'ACCOUNTING','NEW YORK',sysdate,sysdate,123123,123123);
INSERT INTO dept VALUES (20,'RESEARCH','DALLAS',sysdate,sysdate,123123,123123);
INSERT INTO dept VALUES(30,'SALES','CHICAGO',SYSDATE,SYSDATE,123123,123123);
INSERT INTO dept VALUES(40,'OPERATIONS','BOSTON',sysdate,sysdate,123123,123123);

--插入emp表数据:
INSERT INTO emp VALUES(7369,'SMITH','CLERK',7902,to_date('17-12-1980','dd-mm-yyyy'),800,NULL,20,sysdate,sysdate,123123,123123);
INSERT INTO emp VALUES(7499,'ALLEN','SALESMAN',7698,to_date('20-2-1981','dd-mm-yyyy'),1600,300,30,sysdate,sysdate,123123,123123);
INSERT INTO emp VALUES(7521,'WARD','SALESMAN',7698,to_date('22-2-1981','dd-mm-yyyy'),1250,500,30,SYSDATE,SYSDATE,123123,123123);
INSERT INTO emp VALUES(7566,'JONES','MANAGER',7839,to_date('2-4-1981','dd-mm-yyyy'),2975,NULL,20,sysdate,sysdate,123123,123123);
INSERT INTO emp VALUES(7654,'MARTIN','SALESMAN',7698,to_date('28-9-1981','dd-mm-yyyy'),1250,1400,30,SYSDATE,SYSDATE,123123,123123);
INSERT INTO emp VALUES(7698,'BLAKE','MANAGER',7839,to_date('1-5-1981','dd-mm-yyyy'),2850,NULL,30,sysdate,sysdate,123123,123123);
INSERT INTO emp VALUES(7782,'CLARK','MANAGER',7839,to_date('9-6-1981','dd-mm-yyyy'),2450,NULL,10,SYSDATE,SYSDATE,123123,123123);
INSERT INTO emp VALUES(7788,'SCOTT','ANALYST',7566,to_date('19-4-87','dd-mm-yyyy'),3000,NULL,20,SYSDATE,SYSDATE,123123,123123);
INSERT INTO emp VALUES(7839,'KING','PRESIDENT',NULL,to_date('17-11-1981','dd-mm-yyyy'),5000,NULL,10,sysdate,sysdate,123123,123123);
INSERT INTO emp VALUES(7844,'TURNER','SALESMAN',7698,to_date('8-9-1981','dd-mm-yyyy'),1500,0,30,SYSDATE,SYSDATE,123123,123123);
INSERT INTO emp VALUES(7876,'ADAMS','CLERK',7788,to_date('23-5-87','dd-mm-yyyy'),1100,NULL,20,sysdate,sysdate,123123,123123);
INSERT INTO emp VALUES(7900,'JAMES','CLERK',7698,to_date('3-12-1981','dd-mm-yyyy'),950,NULL,30,sysdate,sysdate,123123,123123);
INSERT INTO emp VALUES(7902,'FORD','ANALYST',7566,to_date('3-12-1981','dd-mm-yyyy'),3000,NULL,20,SYSDATE,SYSDATE,123123,123123);
INSERT INTO emp VALUES(7934,'MILLER','CLERK',7782,to_date('23-1-1982','dd-mm-yyyy'),1300,NULL,10,sysdate,sysdate,123123,123123);

插入数据之后的dept表:

插入数据之后的emp表:

1.多表关联批量插入

要求:批量复制部门dept表 loc在 CHICAGO的,且工资大于1600的人员信息到emp_copy表,emp_copy的empno需要使用序列emp_sequence

INSERT INTO emp_copy
SELECT emp_sequence.nextVal,C.* FROM (
  SELECT 
  e.ename ,
  e.JOB ,
  e.mgr ,
  e.hiredate,
  e.sal ,
  e.comm ,
  e.deptno,
  SYSDATE AS CREATEDTIME,
  SYSDATE AS UPDATEDTIME,
  123124 AS CREATEDBY,
  123124 as UPDATEDBY
  FROM emp e, dept d
  WHERE e.deptno = d.deptno
  AND d.loc='CHICAGO'
  and e.sal>=1500 
 )C;

插入之后的emp_copy表结果:

其中SELECT emp_sequence.nextVal,C.* 这种格式保证了C.*的多条数据都能取到不同的序列值

2.多表关联批量更新

要求:批量更新部门dept表 loc在 CHICAGO的,且职位job为'SALESMAN'的员工,comm在原来基础上加200

操作之前的数据:

MERGE INTO emp e
 USING 
 (
  SELECT e1.job, e1.ename,e1.comm FROM emp e1, dept d1
  WHERE e1.deptno = d1.deptno
  AND d1.loc='CHICAGO'
  and e1.job='SALESMAN'
 )t 
 ON (
  e.job = t.job and e.ename = t.ename
 )
 WHEN MATCHED THEN
  UPDATE 
   set e.comm= t.comm+200

操作之后的数据:

其中e.job = t.job and e.ename = t.ename只是展示可以关联多个条件,这里有一个关键点为 USING ( … ) t 中查询到的是一个list,而merge可以对匹配到的list进行批量更新

3.多表关联批量删除

要求:批量删除部门dept表 loc在 CHICAGO的,且工资小于1500的人员信息

操作之前的数据:

DELETE FROM
(
 SELECT c.*
 FROM emp c,dept d
 WHERE d.deptno = c.deptno AND d.loc = 'CHICAGO'
 and c.sal < 1500
);

操作之后的数据:

总结

以上所述是小编给大家介绍的Oracle中多表关联批量插入批量更新与批量删除操作,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对爱安网网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

最新资讯
TCL重组后首年净利下滑17% 李东生称看好显示产业

TCL重组后首年净利下

李东生认为,TCL依然是价值的洼地,“我相信这一轮调整之
苹果股票应该买入、卖出抑或继续持有?

苹果股票应该买入、卖

苹果接近1月份该公司公布第一季强劲业绩后创下的历史
智能手机“卖不动”了? 消费电子上市公司大考来袭

智能手机“卖不动”了

随着下游需求减少逐渐向上游传导,到二季度,消费电子行业
疫情下的“中国芯”:需求前景迷茫增产计划延迟

疫情下的“中国芯”:需

全球快速蔓延的新冠肺炎疫情,大挫前期疯狂上涨的半导体
英特尔资本:CVC巨头的主动式投资

英特尔资本:CVC巨头的

英特尔资本董事总经理、中国区总经理王天琳说:“我们给
Hulu联合创始人基拉尔将接任华纳媒体CEO

Hulu联合创始人基拉尔

AT&T周三宣布,Hulu联合创始人詹森·基拉尔(Jason Kilar)
最新文章
Oracle 给rac创建单实例dg并做主从切换功能

Oracle 给rac创建单实

这篇文章主要介绍了Oracle 给rac创建单实例dg并做主
Oracle中多表关联批量插入批量更新与批量删除操作

Oracle中多表关联批量

这篇文章主要介绍了Oracle中多表关联批量插入,批量更
处理Oracle 监听文件listener.log问题

处理Oracle 监听文件l

这篇文章主要介绍了处理Oracle 监听文件listener.log
Windows Server 2012 安装oracle11g(图文教程)

Windows Server 2012

这篇文章主要介绍了Windows Server 2012 安装oracle11
centos7.7安装oracle11g脚本(推荐)

centos7.7安装oracle1

这篇文章主要介绍了centos7.7安装oracle11g脚本,本文
Oracle中的instr()函数应用及使用详解

Oracle中的instr()函

这篇文章主要介绍了Oracle中的instr()函数应用及使用
炸金花 传奇私服 江西快3 炸金花