Oracle数据的插入insert、更新update、删除delete、truncate举例详解

 更新时间:2024年07月01日 09:37:45   作者:多sir  
SQL语法是所有操作的基础,包括创建、查询、更新和删除数据,下面这篇文章主要给大家介绍了关于Oracle数据的插入insert、更新update、删除delete、truncate的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下

前言

本文主要概述的内容是在Oracle中数据的插入-insert、更新-update、删除-delete、truncate。也会把工作当中可能用到的场景给总结出来,以方便大家需要时查询。

插入数据-insert

单行插入所有列

insert into 表名 values(值1,值2,值3……);
insert into 表名 values(值1,值2,值3……);
insert into 表名 values(值1,值2,值3……);
commit;
……

注意:values值的顺序需要和表的字段顺序保持一致,如果没有具体值需用null填充,否则会报错(没有足够的值)。
执行一行,插入一条数据,若要拆入多行数据,则编辑好对应值,执行多行即可。

部分字段插入数据

工作中有时只想给表中的某几个字段插入值,或者插入所有列但忘记表中的字段顺序时,可以指定字段和对应的值来进行操作。

insert into 表名(字段1,字段2,字段3……)  values(值1,值2,值3……);
commit;

将表1数据插入到表2

这个应用场景和数据备份相似,或者理解为数据的复制都可以,目的是要从一个表中筛选出来的数据复制到另一个表中。
注意:两个表的表结构必须保持一致

insert into 表2 select * from 表1; --将表1的所有数据插入到表2中
commit;

insert into 表2 select * from 表1 where 条件;  --可以加筛选条件
commit;

插入检索出的数据

此方式工作中也经常使用,可以理解为上述几种方式的结合。通过检索出另一张表的数据将值插入到具体指定的列。

insert into 表1(字段1,
                字段2,
                字段3,
                 ……) 
  select 字段1,
         字段2,
         字段3,
          ……
  from 表2
  [筛选条件……]
  
  commit;

更新数据-update

基本的UPDATE语句由三部分组成,分别是:

  • 要更新的表;
  • 列名和它们的新值;
  • 确定要更新哪些行的过滤条件(很重要)
  • 要删除某个列的值,可设置它为NULL(假如表定义允许NULL值)
--更新表中列的值
update 表名 
	set 字段1 = 值1, 
		字段2 = 值2,
		……
where 筛选条件;

--删除某列的值
update 表名 set 字段1 = NULL where 筛选条件;

删除数据-delete & truncate

从一个表中删除(去掉)数据,使用DELETE语句。有两种使用DELETE的方式:

  • 从表中删除特定的行
  • 从表中删除所有行

注意:where子句很重要,因为稍不注意,就会错误地删除表中所有行。

DELETE删除整行而不是删除列。要删除指定的列,请使用 UPDATE 语句。

如果想从表中删除所有行,不要使用 DELETE。可使用 TRUNCATE 语句,它完成相同的工作,而速度更快(因为不记录数据的变动)。

--删除符合条件的某行/某几行数据
delete from 表名 where 筛选条件;  

--删除表中的所有行 
delete from 表名;  
truncate table 表名;  

dalete和truncate的主要区别

  • delete语句是一种DML(数据操作语言)语句,而truncate语句是一种DDL(数据定义语言)语句。这意味着delete语句是用于操作数据的,而truncate语句是用于操作表结构的。
  • delete语句可以使用where子句来指定删除的条件,而truncate语句不能使用where子句,只能整表删除。
  • delete删除数据时,会将每一行的数据都放入回滚段(rollback segment)中,以便在事务回滚时可以还原数据。而truncate并不会将数据放入回滚段中,无法回滚。
  • delete语句删除数据是逐行进行,对于大表来说,删除数据的效率相对较低。而truncate语句是直接删除整个表的数据,因此对于大表来说,删除数据的效率相对较高。

附:Oracle一次插入多条记录

方式1:

要向数据库中写入多条记录,记录集已经确定,如果一次一次插入势必影响效率。

解决方法:

注意:上面最后一个select之后没有union all,否则报错。

方式2:

总结

到此这篇关于Oracle数据的插入insert、更新update、删除delete、truncate的文章就介绍到这了,更多相关Oracle数据插入更新删除内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Oracle同步数据到kafka的方法

    Oracle同步数据到kafka的方法

    本文主要介绍如何使用kafka-connect-oracle开源工具,将Oracle dml产生的数据实时同步至kafka,供kafka消费,对Oracle同步数据到kafka的方法感兴趣的朋友一起看看吧
    2022-02-02
  • Oracle 12c修改字符集的方法(解决数据导入后中文乱码及ORA-12899错误)

    Oracle 12c修改字符集的方法(解决数据导入后中文乱码及ORA-12899错误)

    之前在Windows上安装的Oracle,现在迁移到Linux上,把dmp文件导入Linux的时候发现字段的注释和存储过程中的中文是问号?,而且导入的时候还会报ORA-12899错误,其实这些都是字符集问题,所以本文给大家介绍了Oracle 12c修改字符集的方法,需要的朋友可以参考下
    2024-04-04
  • Oracle重建控制文件的实例教程

    Oracle重建控制文件的实例教程

    前些天在做Oracle数据库恢复测试时,因为一些异常操作导致控制文件出了问题,数据库无法正常使用,下面这篇文章就来给大家介绍了关于Oracle重建控制文件的相关资料,需要的朋友可以参考借鉴,下面来一起看看吧
    2018-05-05
  • Oracle中查看引起Session阻塞的2个脚本分享

    Oracle中查看引起Session阻塞的2个脚本分享

    这篇文章主要介绍了Oracle中查看引起Session阻塞的2个脚本分享,本文给出了2个脚本来查询导致Session阻塞的原因,并给出Kill引起阻塞的Session方法,需要的朋友可以参考下
    2014-10-10
  • Oracle常见问题解决方案汇总

    Oracle常见问题解决方案汇总

    今天小编就为大家分享一篇关于Oracle常见问题解决方案汇总,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-02-02
  • Oracle数据库中创建自增主键的实例教程

    Oracle数据库中创建自增主键的实例教程

    Oracle的字段自增功能,可以利用创建触发器的方式来实现,接下来我们就来看看Oracle数据库中创建自增主键的实例教程,需要的朋友可以参考下
    2016-05-05
  • oracle索引的测试实例代码

    oracle索引的测试实例代码

    这篇文章主要给大家介绍了关于oracle索引测试的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-01-01
  • oracle 11g RAC 常用命令整理分享

    oracle 11g RAC 常用命令整理分享

    很多朋友会经常用到oracle 11g RAC的命令,今天我也用到了,同时也整理了一些常用的命令,以备不时之需
    2012-11-11
  • SQL Developer迁移第三方数据库单表到Oracle的全过程

    SQL Developer迁移第三方数据库单表到Oracle的全过程

    这篇文章主要介绍了SQL Developer迁移第三方数据库单表到Oracle的全过程,文章通过图文结合的方式给大家讲解的非常详细,具有一定的参考价值,需要的朋友可以参考下
    2024-06-06
  • oracle中的一些常用函数及示例

    oracle中的一些常用函数及示例

    这篇文章主要给大家介绍了关于oracle中的一些常用函数及示例的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-11-11

最新评论