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次。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

游戏反Frida注入检测方案

在游戏安全对抗过程中&#xff0c;有不少外挂的实现基于对游戏内存模块进行修改&#xff0c;这类外挂通常会使用内存修改器&#xff0c;除此之外&#xff0c;还有一种门槛相对更高、也更难检测的「注入挂」。 据FairGuard游戏安全数据统计&#xff0c;在游戏面临的众多安全风险…

keepalive路由缓存实现前进刷新后退缓存

1.在app.vue中配置全局的keepalive并用includes指定要缓存的组件路由name名字数组 <keep-alive :include"keepCachedViews"><router-view /></keep-alive>computed: {keepCachedViews() {console.log(this.$store.getters.keepCachedViews, this.…

cmake和vscode 下的cmake的使用详解(一)。

本文的内容 参考如下内容。 1.【基于VSCode和CMake实现C/C开发 | Linux篇】https://www.bilibili.com/video/BV1fy4y1b7TC?vd_source0ddb24a02523448baa69b0b871ab50f7 2.Notion – The all-in-one workspace for your notes, tasks, wikis, and databases. 3.关于如何利用…

用HeidiSQL在MySQL中创建新的数据库

用有权限的用户登录&#xff1a; 右键单击&#xff0c;选择&#xff1a; 输入要创建的数据库名称&#xff0c;然后点击“确定”&#xff1a; 刷新下&#xff0c;就看到新创建的数据库了&#xff1a; 在新创建的数据库中&#xff0c;就可以做其它操作了&#xff0c;例如…

uniapp微信小程序实现地图展示控件

最终实现效果&#xff1a; 地图上展示控件&#xff0c;并可以点击。 目录 一、前言 二、在地图上展示控件信息 点击后可进行绘制面图形 1.使用cover-view将控件在地图上展示 2.设置控件样式&#xff0c;使用好看的图标 3.控件绑定点击事件 一、前言 原本使用的是control…

nginx 配置前端项目添加https

可申请阿里云免费证书 步骤省略… nginx 配置 server {listen 8050; #默认80端口 如果需要所有访问地址都是https 需要注释listen 8443 ssl; #https 访问的端口 &#xff0c;默认443server_name 192.168.128.XX; #域名 或 ip# 增加ssl#填写证书文件…

Java多线程-第20章

Java多线程-第20章 1.创建线程 Java是一种支持多线程编程的编程语言。多线程是指在同一程序中同时执行多个独立任务的能力。在Java中&#xff0c;线程是一种轻量级的子进程&#xff0c;它是程序中的最小执行单元。Java的多线程编程可以通过两种方式实现&#xff1a;继承Threa…

IntelliJ IDEA安装使用教程

IntelliJ IDEA是一个流行的Java 集成开发环境&#xff08;IDE&#xff09;&#xff0c;由JetBrains公司开发。它是一款全功能的IDE&#xff0c;支持多种编程语言&#xff0c;如Java、Kotlin、Groovy、Scala、Python、JavaScript、HTML、CSS等等。IntelliJ IDEA 提供了高效的代码…

代码随想录算法训练营 ---第五十一天

1.第一题&#xff1a; 简介&#xff1a; 本题相较于前几题状态复杂了起来&#xff0c;因为多了一个冷冻期。本题讲解可去代码随想录看&#xff0c;这里差不多只是加了些自己的理解。 动规五部曲&#xff0c;分析如下&#xff1a; 确定dp数组以及下标的含义 dp[i][j]&#x…

C#文件流二进制文件的读写

目录 一、BinaryWriter类 二、BinaryReader类 三、示例 1.源码 2.生成效果 二进制文件的写入与读取主要是通过BinaryWriter类和BinaryReader类来实现的。 一、BinaryWriter类 BinaryWriter类以二进制形式将基元类型写入流&#xff0c;并支持用特定的编码写入字符串&#…

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

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

使用Pytorch从零开始实现CLIP

生成式建模知识回顾: [1] 生成式建模概述 [2] Transformer I&#xff0c;Transformer II [3] 变分自编码器 [4] 生成对抗网络&#xff0c;高级生成对抗网络 I&#xff0c;高级生成对抗网络 II [5] 自回归模型 [6] 归一化流模型 [7] 基于能量的模型 [8] 扩散模型 I, 扩散模型 II…

sublime Text使用

1、增加install 命令面板 工具(tool)->控制面板(command palette) -> 输入install ->安装第一个install package controller&#xff0c;以下安装过了&#xff0c;所以没展示 2、安装json格式化工具 点击install package&#xff0c;等几秒会进入控制面板&#xff0…

润申信息企业标准化管理系统 SQL注入漏洞复现

0x01 产品简介 润申信息科技企业标准化管理系统通过给客户提供各种灵活的标准法规信息化管理解决方案&#xff0c;帮助他们实现了高效的标准法规管理&#xff0c;完成个性化标准法规库的信息化建设。 0x02 漏洞概述 润申信息科技企业标准化管理系统 CommentStandardHandler.as…

高级I/O 基础概念

文章目录 什么是高级I/O五种常见高级I/O同步IO和异步IO多路转接是异步IO吗 什么是高级I/O 高级I/O&#xff08;Advanced I/O&#xff09;是指在计算机系统中进行输入和输出操作时使用的一种更高级的接口和技术。它提供了比传统的基本I/O操作更丰富和灵活的功能&#xff0c;以满…

echarts实现3D柱状图

效果如图 let setData function(data, constData, showData) {data.filter(function(item) {if (item) {constData.push(1);showData.push(item);} else {constData.push(0);showData.push({value: 1,itemStyle: {normal: {borderColor: "rgba(0,0,0,0)",borderWidt…

传统算法:使用 Pygame 实现线性查找

使用 Pygame 模块实现了线性查找的动画演示。首先,它生成一个包含随机整数的数组,并通过 Pygame 在屏幕上绘制这个数组的条形图。接着,通过线性查找算法对数组进行查找,动画效果可视化每一步的变化。在查找的过程中,程序逐个遍历数组元素,如果找到目标值,将相应的元素高…

最简单的链路追踪收集器

链路追踪可帮助您快速了解程序服务之间的调用关系&#xff0c;并快速洞悉内部发生的情况。主流的链路追踪系统有zipkin,jaeger,skywalking等&#xff0c;由于opentelemetry的存在&#xff0c;都具有opentelemetry的转换器。 我们利用opentelemetry来进行zipkin,jaeger,skywalk…

Vue H5页面长按保存为图片

安装依赖&#xff1a;npm install html2canvas -d <template><div class"index"><div id"captureId" class"capture" v-show"firstFlag"><ul><li>1</li><li>2</li><li>3<…

组合(回溯算法)

77. 组合 - 力扣&#xff08;LeetCode&#xff09; 题目描述 给定两个整数 n 和 k&#xff0c;返回范围 [1, n] 中所有可能的 k 个数的组合。 你可以按 任何顺序 返回答案。 样例输入 示例 1&#xff1a; 输入&#xff1a;n 4, k 2 输出&#xff1a; [[2,4],[3,4],[2,3],…