Oracle 单表插入/多表插入(Single Table Insert/Multi-table Insert)

数据库应用中,我们经常需要向表中插入数据,insert语句是最常用的数据插入方式,根据目标表的数量,可以分为单表插入和多表插入。

目录

一、 单表插入(Single Table Insert)

二、 多表插入(Multi-table Insert)

2.1 单目标表多列插入

2.2 多目标表条件插入

2.3 All和First关键字


、 单表插入(Single Table Insert

单表插入是最常用插入方式,使用insert into … 语句向单一表的指定列或者全部列加载数据,也可以利用子查询从已有表中加载数据。

先建一张测试表,bonus列增加了default属性:

create table wage(
id number(6),
name varchar2(32),
salary number(6),
bonus number(6) default 100);

insert 语句中在表后提供列名,可以向指定列插入数据

insert into wage(id,name,salary) values(1,'Vincent',1000);

Select * from wage;

  • values子句中提供值的数量需要和列的数量相同
  • 这里指定向id,name,salary插入值,bonus列并未提供值
  • bonus列在创建时指定了default 100,所以被赋予了默认值100

如果表名后没有指明列,意味着向所有列插入数据

insert into wage values(2,'Victor',2000,200);

insert into wage values(3,'Grace',3000,default);

  • values子句提供的值数量需要和表列数量相同
  • 即使某些列有默认值也不能省略,可以用default关键字来赋默认值

insert into … select … 可以使用子查询向表中插入数据,过程中可以是对数据进行加工。要注意子查询的列一定要和加载目标表的列数量相等,如果忽略目标表的列只提供表名,那么子查询必须为每一列都提供数据:

create table wage_bak as select * from wage where 1=2;

Insert into wage_bak select id, name, salary+500, bonus from wage where id=1;

select * from wage_bak;

  • Create table 语句复制从wage复制了一张表wage_bak,where 1=2用来控制不复制数据
  • Insert into … select … 将ID为1的数据从wage加载到wage_bak中,同时salary加500
  • 其实这里create table一步就可以完成表的创建和数据加载,仅为了演示拆成2步

二、 多表插入(Multi-table Insert

多表插入非常适合数据整理分配场景,如果利用单表插入,我们需要对每个条件查询一次源表并插入目标表,而多表插入可以直接定义多个条件,一次查询即可将所有数据分布到不同的表中。

在多表插入中,你必须通过子查询加载数据。但与单表插入不同的是,你可以更灵活的对子查询返回的每条数据进行条件判断,然后再指定插入一张或多张表。

这里再建一张测试表income,用多表插入的方式将数据从wage加载到income,注意income的表结构与wage不同,它新增了type列来区分收入类型。

create table income(
id number(6),
name varchar2(64),
type varchar2(64),
amount number(6));

2.1 单目标表多列插入

将数据从wage加载到income,要求当type为"sal"时,加载salary列,当type为"bou"时,加载bonus列:

insert all
into income(id, name, type, amount) values(id, name, 'sal', salary)
into income(id, name, type, amount) values(id, name, 'bou', bonus)
select id,name,salary,bonus from wage;

select * from income;

  • 利用多表查询,子查询返回列数量可以大于目标表列数量,你可以定义多个into子句来分配这些列
  • 示例定义了2个into条件,一次查询将salary和bouns插入目标表的amount列,并完成区分
  • 在数据插入较复杂,特别是源表数据量很大的场景,利用多表插入可以避免对源表反复查询

2.2 多目标表条件插入

现需要将wage表中记录根据工资高低,把数据分布到3张不同的表中,先通过wage复制3张表:

create table low_wage as select * from wage where 1=2;

create table medium_wage as select * from wage where 1=2;

create table high_wage as select * from wage where 1=2;

通过多表插入的when … then … else 语句可以对子查询的每一条数据进行判断,将满足条件的数据分配到指定表中:

insert all
when salary <= 1000 then into low_wage
when salary >1000 and salary <=2000 then into medium_wage
else into high_wage
select * from wage;

Select * from low_wage;
Select * from medium_wage;
Select * from high_wage;

  • 第一个when子句将salary小于等于1000的记录插入low_wage表
  • 第二个when子句将salary在1000至2000的记录插入medium_wage表
  • else子句将剩下的记录插入high_wage表,如果省略else语句,那么不满足上面条件的记录不会做任何处理

2.3 AllFirst关键字

上面示例中,insert后面的关键字是all,代表每条记录都会针对每个when条件做评估。

另一个关键字first,insert first表示发现第一个满足的条件即"熔断",剩余的条件不再评估。all/first关键字在条件范围重叠时会导致不同的结果,在实际应用中要注意。

下面将low_wage表清空,设置两个重叠的条件,分别用all和first关键字插入:

truncate table low_wage;

insert all
when salary <= 1000 then into low_wage
when salary <= 1500 then into low_wage
select * from wage where salary=1000;

select * from low_wage;

  • 子查询仅返回1条记录,但由于其同时满足<=1000和<=1500,all关键字对两个条件都进行判断且满足,并插入了2次。
truncate table low_wage;

insert first
when salary <= 1000 then into low_wage
when salary <= 1500 then into low_wage
select * from wage where salary=1000;

select * from low_wage;

  • 将关键字all替换为first,当<=1000条件满足时,后续<=1500的条件则不再判断,因此数据只插入了1次。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/206745.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Set集合的特点

Set系列集合特点&#xff1a; 无序&#xff1a;添加数据的顺序和获取出的数据顺序不一致&#xff1b;不重复&#xff1b;无索引&#xff1b; HashSet&#xff1a;无序&#xff0c;不重复&#xff0c;无索引 LinkedHashSet&#xff1a;有序&#xff0c;不重复&#xff0c;无索引…

DS八大排序之直接选择排序和堆排序

前言 上一期我们已经介绍了&#xff0c;排序、为什么要有排序以及排序在实际生活中的应用。并且介绍并实现了直接插入排序和它的优化即希尔排序~&#xff01;本期我们再来学习一组排序 ---- "选择排序"即直接选择排序和堆排序~&#xff01; 本期内容介绍 直接选择排…

【linux防火墙】设置开启路由转发,SNAT和DNAT转换原理及应用实操,添加自定义链归类iptables规则

目录 一、关于iptables规则的保存 1.1持久保存规则 1.2加载规则 1.3开机自动加载规则 1.4使用iptables-service软件来进行规则的保存和加载&#xff08;不建议使用&#xff09; 二、SNAT和DNAT的原理和应用 SNAT的原理与应用&#xff1a; DNAT的原理和应用&#xff1a; …

透彻理解二叉树中序遍历的应用

关卡名 二分搜索树 我会了✔️ 内容 1.有序数组转为二叉搜索树 ✔️ 2.寻找两个正序数组的中位数 ✔️ 1 有序数组转为二叉搜索树 LeetCode108 给你一个整数数组 nums &#xff0c;其中元素已经按 升序 排列&#xff0c;请你将其转换为一棵 高度平衡 二叉搜索树。 高度…

深入理解Zookeeper系列-2.Zookeeper基本使用和分布式锁原理

&#x1f44f;作者简介&#xff1a;大家好&#xff0c;我是爱吃芝士的土豆倪&#xff0c;24届校招生Java选手&#xff0c;很高兴认识大家&#x1f4d5;系列专栏&#xff1a;Spring源码、JUC源码、Kafka原理、分布式技术原理&#x1f525;如果感觉博主的文章还不错的话&#xff…

全志XR806基于FreeRTOS下部署竞技机器人先进模糊控制器

前言 很荣幸参与到由“极术社区和全志在线联合组织”举办的XR806开发板试用活动。本人热衷于各种的开发板的开发&#xff0c;同时更愿意将其实现到具体项目中。秉承以上原则&#xff0c;发现大家的重心都放在开发中的环境构建过程&#xff0c;缺少了不少实际应用场景的运用&am…

【小布_ORACLE笔记】Part11-5 RMAN Backups

【小布_ORACLE笔记】Part11-5 RMAN Backups 文章目录 【小布_ORACLE笔记】Part11-5 RMAN Backups1. 增量备份&#xff08;Incremental Backups)1.1差异增量备份&#xff08;Differential Incremental Backup&#xff09;1.2累积增量备份&#xff08;Cumulative Incremental Bac…

记RocketMQ本地开发环境搭建始末

前言 最近工作中涉及到了RocketMQ的应用&#xff0c;为方便开发决定本地搭建一套RocketMQ的使用环境。 果然实践是个好东西... VMware虚拟环境搭建 这个网上有很多教程&#xff0c;只会比我写的详细有条理&#xff0c;这里就不在赘述了。 虚拟机搭建好之后每次重启电脑都无…

【投稿优惠、可EI检索】2024年机器人学习与自动化算法国际学术会议(IACRLAA 2024)

2024年机器人学习与自动化算法国际学术会议(IACRLAA 2024) 2024 International Academic Conference on Intelligent Control Systems and Robot Learning 一、【会议简介】 本届机器人学习与自动化算法国际学术会议(IACRLAA 2024)将于2024年1月23日在北京盛大开幕。这次会议将…

Vue3 Router跳转传参

最近遇到这个问题router跳转传参&#xff0c;真是要了老命了。 根据网上各位大神给出的方法&#xff0c;试了 import { useRouter } from vue-routerconst router useRouter()//1. 无法跳转 router.push(name:,params:{})//2. 可以跳转, 但需要在定义router同时定义占位符&a…

(五)基于高尔夫优化算法GOA求解无人机三维路径规划研究(MATLAB代码)

一、无人机模型简介&#xff1a; 单个无人机三维路径规划问题及其建模_IT猿手的博客-CSDN博客 参考文献&#xff1a; [1]胡观凯,钟建华,李永正,黎万洪.基于IPSO-GA算法的无人机三维路径规划[J].现代电子技术,2023,46(07):115-120 二、高尔夫优化算法GOA简介 高尔夫优化算法…

react-flip-move结合array-move实现前端列表置顶效果

你有没有遇到这样的需求&#xff1f;点击左侧列表项&#xff0c;则像聊天会话窗口一样将被点击的列表项置顶。 如果只是单纯的置顶的话&#xff0c;直接使用array-move就可以实现了&#xff0c;但置顶效果多少有点突兀~ 先上代码&#xff0c;直接使用array-move的情况&#xf…

用于缓存一些固定名称的小组件

项目中&#xff0c;用于缓存姓名、地名、单位名称等一些较固定名称的id-name小组件。用于减少一些表的关连操作和冗余字段。优化代码结构。扩展也方便&#xff0c;写不同的枚举就行了。 具体用法&#xff1a; {NameCacheUser.USER.getName(userId);NameCacheUser.ACCOUNT.getN…

文心一言 VS 讯飞星火 VS chatgpt (146)-- 算法导论12.2 1题

一、用go语言&#xff0c;假设一棵二叉搜索树中的结点在1到 1000 之间&#xff0c;现在想要查找数值为 363 的结点。下面序列中哪个不是查找过的序列? a.2&#xff0c;252&#xff0c;401&#xff0c;398&#xff0c;330&#xff0c;344&#xff0c;397&#xff0c;363。 b.9…

vtk中二次曲面的显示

官方示例地址&#xff1a; https://examples.vtk.org/site/Cxx/Visualization/DisplayQuadricSurfaces/ 显示效果&#xff1a; 源码&#xff1a; import vtk import vtkmodules.vtkInteractionStyle import vtkmodules.vtkRenderingOpenGL2 from vtkmodules.vtkCommonColor i…

SAP SD 创建交货单 报错 VL461 VL248

因为生产环境已经被改好了&#xff0c;无法跟踪 所以换到测试环境重现一把&#xff0c;如何追根究底 对比正常订单发现 计划行 VBEP-LMENG,VBEP-BMENG这两个字段上的值跟 订单数量不一致。 尝试修改2者的数据跟订单数据一致&#xff0c;则可以正常创建交货单 实际原因是&a…

Neo4j 数据库管理 数据备份与恢复(头歌)

文章目录 第1关&#xff1a;数据备份与恢复任务描述相关知识数据备份数据导入 编程要求测试说明答案测试前准备Cypher 代码数据备份与导入 第1关&#xff1a;数据备份与恢复 任务描述 本关任务&#xff1a;熟练掌握数据备份与恢复。 相关知识 为了完成本关任务&#xff0c;…

INFINI Easysearch 与华为鲲鹏完成产品兼容互认证

何为华为鲲鹏认证 华为鲲鹏认证是华为云围绕鲲鹏云服务&#xff08;含公有云、私有云、混合云、桌面云&#xff09;推出的一项合作伙伴计划&#xff0c;旨在为构建持续发展、合作共赢的鲲鹏生态圈&#xff0c;通过整合华为的技术、品牌资源&#xff0c;与合作伙伴共享商机和利…

基于单片机的排队叫号系统设计

1&#xff0e;设计任务 利用AT89C51单片机为核心控制元件,设计一个节日彩灯门&#xff0c;设计的系统实用性强、操作简单&#xff0c;实现了智能化、数字化。 基本要求&#xff1a;利用单片机AT89C51设计排队叫号机&#xff0c;能实现叫号功能。 创新&#xff1a;能显示叫号…

算法通关村第一关—链表高频面试题(白银)

链表高频面试题 一、五种方法解决两个链表的第一个公共子节点的问题 面试 02.07.链表相交1.首先想到的是暴力解&#xff0c;将第一个链表中的每一个结点依次与第二个链表的进行比较&#xff0c;当出现相等的结点指针时&#xff0c;即为相交结点。虽然简单&#xff0c;但是时间…