我的编程空间,编程开发者的网络收藏夹
学习永远不晚

数据库insert高级语法用法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

数据库insert高级语法用法

这篇文章主要介绍“数据库insert高级语法用法”,在日常操作中,相信很多人在数据库insert高级语法用法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”数据库insert高级语法用法”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

有这样一个业务需求,要求根据不同条件将源数据插入到不同的表中,源数据表更新十分频繁,这样的一个业务需求应该怎么做呢?我先给出源表结构和需要插入的表结构:
更新十分频繁的源表:
create table people(id number,name varchar2(20),sex char(3),address varchar2(500));

给源表插入数据:
insert into people 
values(1,'张翠山','男','武当山');
insert into people 
values(2,'殷素素','女','天鹰教');
insert into people 
values(3,'张无忌','男','明教');
insert into people 
values(4,'赵敏','女','皇室');
insert into people 
values(5,'周芷若','女','峨眉山');
insert into people 
values(6,'成昆','男','少林寺');
commit;
查询一下people结果,如图所示:
数据库insert高级语法用法

待插入的几张表结构:
create table people_1(id number,name varchar2(20));
create table people_2(id number,sex char(3));
create table people_3(sex char(3),address varchar2(500));
现在的业务需求是,将ID<=4的记录插入到people_1中,SEX='男'的插入到people_2,剩下的插入到people_3中。乍一看,此需求可以这样做insert into people_1 select id,name from people where id<=4; insert into people_2 select id,sex from people where SEX='男'; insert into people_3 select sex,sddress from people where id>4 and SEX!='男';但是people是一个频繁DML的表,如果分成这样子三步执行,在数据量特别大的情况下,每步插入操作会消耗较长时间,在这一段时间之内,又会有大批量数据改变,导致三步操作的表数据基数都不一样,结果当然会有偏差。因此,在这里我们用到了insert的高级语法。
SQL如下:
insert all
when id<=4 then into people_1 values(id,name)
  when sex='男' then into people_2 values(id,sex)
    else into people_3 values(sex,address)
select * from people;
结果如下:
PEOPLE_1:                   PEOPLE_2:         PEOPLE_3:
数据库insert高级语法用法       数据库insert高级语法用法    数据库insert高级语法用法

如果我只想ID=1在people_1中插入之后就不在people_2中插入,那么可以使用insert first,它会从前到后进行判断,如果一条记录在前面已经插入,则在之后略过此条记录。
SQL如下:
insert first
when id<=4 then into people_1 values(id,name)
  when sex='男' then into people_2 values(id,sex)
    else into people_3 values(sex,address)
select * from people;
结果如下:
PEOPLE_1:                   PEOPLE_2:         PEOPLE_3:
数据库insert高级语法用法   数据库insert高级语法用法       数据库insert高级语法用法

当然,这个是根据条件插入的,当没有条件的时候,可以直接进行插入。
SQL如下:
insert all/first
into people_1 values(id,name)
into people_2 values(id,sex)
into people_3 values(sex,address)
select * from people;
其实很多时候,现实业务的要求oracle都为我们考虑到了,而且其性能通常强于我们自己写的PL/SQL,更多的精彩业务实现,还等着我们去探索。

到此,关于“数据库insert高级语法用法”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

数据库insert高级语法用法

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

SQL 数据的插入(INSERT 语句的使用方法)

目录一、什么是 INSERT二、INSERT 语句的基本语法三、列清单的省略四、插入 NULL五、插入默认值六、从其他表中复制数据请参阅学习重点使用 INSERT 语句可以向表中插入数据(行)。原则上,INSERT 语句每次执行一行数据的插入。将列名和值用逗号
SQL 数据的插入(INSERT 语句的使用方法)
2020-12-13
2024-04-02

MySQL INSERT锁与数据库高可用方案

MySQL INSERT锁是指在向数据库中插入新数据时,会对相关表进行加锁操作,防止其他操作对该表进行修改或插入操作。这种锁可以保证数据的一致性和完整性,但有可能会导致性能下降,特别是在高并发的情况下。对于数据库高可用方案,可以考虑以下几
MySQL INSERT锁与数据库高可用方案
2024-08-18
MySql数据库语句用法
2020-02-11

数据库-SQL 语法

数据库-SQL 语法     二十余年如一梦,此身虽在堪惊。 简介:数据库-SQL 语法一、基础模式定义了数据如何存储、存储什么样的数据以及数据如何分解等信息,数据库和表都有模式。主键的值不允许修改,也不允许复用(不能将已经删除的主键值赋给新数据行的主键)。S
数据库-SQL 语法
2016-10-08

C语言的高级用法

在C语言中,定义了4个内存区间:代码区;全局变量和静态变量区;局部变量区即栈区;动态存储区,即堆区;具体如下。
C语言代码2024-12-01

Cython库:从基本用法到高级用法

为了解决这个问题,开发者们创造了Cython库,它是Python语言的扩展,结合了Python的简洁性和C语言的高性能。本文将深入探索Cython库,从基本用法到高级用法,帮助读者充分了解和利用Cython提升Python代码的性能。

MySQL INSERT锁与数据库高可用架构的选择

在MySQL中,INSERT锁是一种排他锁,用于阻止其他事务在插入数据时对同一行数据进行修改。这种锁在插入数据时会自动被获取,确保数据的一致性和完整性。当涉及到数据库高可用架构的选择时,应该考虑以下几点:主从复制:主从复制是最常见的高可用
MySQL INSERT锁与数据库高可用架构的选择
2024-08-14

有哪些C语言的高级用法

本篇内容主要讲解“有哪些C语言的高级用法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“有哪些C语言的高级用法”吧!整形溢出和提升大部分 C 程序员都以为基本的整形操作都是安全的其实不然,看下面这
2023-06-16

SqlServer中BULK INSERT用法简介,批量插入数据

BULK INSERT是SqlServer中用于批量插入数据的命令。它可以将来自外部文件的数据快速加载到表中,比逐行插入数据的方式更高效。BULK INSERT的用法如下:1. 创建目标表:在执行BULK INSERT之前,需要先创建一个目
2023-09-16

编程热搜

目录