insert all (复合表插入),是将一个查询结果同时插入多个表中的功能。使用insert all的好处是通过读取一次源表就可以插入多张目标表,减少重复读取的开销。语法:INSERT [ALL] [conditional_insert_clause][insert_into_clause value_clause] (subquery);
conditional_insert_clause is免费云主机域名:[ALL] [FIRST][WHEN condition THEN] [insert_into_clause value_clause][ELSE] [insert_into_clause value_clause]
all:不考虑先后关系,只要满足条件,就全部插入;
first:考虑先后关系,如果有数据满足第一个when条件又满足第二个when条件,则执行第一个then插入语句,第二个then就不插入第一个then已经插入过的数据了。
其区别也可描述为,all只要满足条件,可能会作重复插入;first首先要满足条件,然后筛选,不做重复插入
示例:
指定insert first 当第一个when条件成立时,执行该when条件后的语句,并且跳过后面的 WHEN 子句(后面的when语句都不再考虑满足第一个When子句的记录,即使该记录满足when语句中的条件)。
上面两条语句区别在第二个when条件,insert all 中 第二个条件会插入orders 表中c1
相关推荐: 对于undotbs01.dbf文件太大的处理办法
缩小Oracle目录下UNDOTBS01.DBF文件的大小使用sys用户登录Oracle方法一:重置表空间大小linux下执行ALTER DATABASE DATAFILE ‘/opt/oracle/oradata/res/undotbs01.dbf’ RES…
免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。