linux update语句,关于Update语句的调整(5-1)

调整方法二:建立临时表+Merge

(1)

1.调整方法二:建立临时表+Merge

通过建立临时表保存中间结果并结合merge语句的方法对语句进行调整。

背景知识简介

l临时表简介

数据库中的所有会话均可以访问临时表,但只有插入数据到临时表中的会话才能看到本身插入的数据。可以把临时表指定为事务相关(默认)或者是会话相关:

ON COMMIT DELETE ROWS:指定临时表是事务相关的,Oracle在每次提交后截断表。

ON COMMIT PRESERVE ROWS:指定临时表是会话相关的,Oracle在会话中止后截断表。

通过使用Oracle的临时表后可以并行的对数据进行处理,有效的提高了数据处理的速度。

下面是创建临时表的例子

CREATE GLOBAL TEMPORARY TABLE TEMP_TEST

AS

SELECT *FROM DBA_OBJECTS

WHERE 1 = 2

/

CREATE INDEX IDX_OBJECT_ID ON TEMP_TEST(OBJECT_ID)

/

在临时表上插入数据比在普通表上插入数据要快得多:

SQL> SET TIMING ON

SQL>

SQL> DROP TABLE TEMP_TEST_1

2/

表已丢弃。

已用时间:00: 00: 00.00

SQL> CREATE GLOBAL TEMPORARY TABLE TEMP_TEST_1

2AS

3SELECT *FROM DBA_OBJECTS

4WHERE 1=2

5/

表已创建。

已用时间:00: 00: 00.01

SQL>

SQL> DROP TABLE TEMP_TEST_2

2/

表已丢弃。

已用时间:00: 00: 00.03

SQL> CREATE TABLE TEMP_TEST_2

2AS

3SELECT *FROM DBA_OBJECTS

4WHERE 1=2

5/

表已创建。

已用时间:00: 00: 00.02

SQL>

SQL> INSERT INTO TEMP_TEST_1 SELECT * FROM DBA_OBJECTS

2/

已创建47622行。

已用时间:00: 00: 01.04

SQL> INSERT INTO TEMP_TEST_2 SELECT * FROM DBA_OBJECTS

2/

已创建47622行。

已用时间:00: 00: 04.07

SQL>

我们看看,47622行记录插入临时表只需要01.04,而插入普通表则需要04.07。

lMerge语句简介

Merge语句的基本语法:

MERGE INTO .TABLE1

USING .TABLE2

ON (TABLE1.= TABLE2.)

WHEN MATCHED THEN

WHEN NOT MATCHED THEN ;

Merge把一张表中的数据插入到另外一张表中或者更新对应的记录,插入与更新由ON子句决定。

下面是使用Merge语句的一个例子:

SQL>

SQL> drop table t3

2/

表已丢弃。

已用时间:00: 00: 00.00

SQL> create table t3 as select * from dba_objects where rownum <= 30

0

2/

表已创建。

已用时间:00: 00: 00.02

SQL> drop table t4

2/

表已丢弃。

已用时间:00: 00: 00.00

SQL> create table t4 as select * from dba_objects

2/

表已创建。

已用时间:00: 00: 00.07

SQL> create index idx_t3_id on t3(object_id)

2/

索引已创建。

已用时间:00: 00: 00.01

SQL> create index idx_t4_id on t4(object_id)

2/

索引已创建。

已用时间:00: 00: 00.05

SQL> merge into t3

2using t4

3on (t3.object_id = t4.object_id)

4when matched then update set t3.object_name = t4.object_name

5when not matched then insert (t3.object_id,t3.object_name)

6values (t4.object_id,t4.object_name)

7/

47628行已合并。

已用时间:00: 00: 06.00SQL>

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

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

相关文章

JavaWeb总结(四)

使用Servlet发送服务器端响应信息 Servlet API中定义一个专门的接口类javax.servlet.http.HttpServletResponse用于创建HTTP响应&#xff0c;包括HTTP协议的状态行、响应头以及消息体&#xff1b; HTTP响应示例 设置响应状态行 - 状态行分为HTTP协议、状态码和状态描述三个部分…

java ee开发环境_设置Java EE 6开发环境

java ee开发环境本教程简要说明了如何设置典型的环境来开发基于Java EE 6的应用程序。 除了可以正常工作的Windows XP客户端具有足够的CPU能力和内存外&#xff0c;本教程没有其他先决条件。 在教程中&#xff0c;我们将需要安装以下组件&#xff1a; Java 6 JDK更新26 适用于…

学生成绩管理系统简单c语言源代码,c语言学生成绩管理系统源代码

好用#include#include#includetypedef struct stu{char sz_Name[20]; char sz_ID[11]; char sz_Class[10]; float r_Score[3];}student;#define STU_MAXSIZE 60int i_stuSize;student stu[STU_MAXSIZE];/*显示主菜单*/void Dis_Main_Menu(){printf("\n 学生成绩管理系统 \…

JavaWeb前端:HTML5 简介

简单了解HTML5知识转载于:https://www.cnblogs.com/vivian-test/p/5949773.html

c语言程序运行结果怎么看,帮忙看看我这个C语言程序有什么错误,运行结果不正确...

C语言的最大特点是&#xff1a;功能强、使用方便灵活。C编译的程序对语法检查并不象其它高级语言那么严格&#xff0c;这就给编程人员留下“灵活的余地”&#xff0c;但还是由于这个灵活给程序的调试带来了许多不便&#xff0c;尤其对初学C语言的人来说&#xff0c;经常会出一些…

JSF 2.2在30秒内创建一个自定义Hello World组件

让我们直接跳到很酷的东西上&#xff0c;说在JSF 2.0中&#xff0c;通过在Facelet标记库&#xff08; *taglib.xml &#xff09;中对其进行配置&#xff0c;使页面作者可以使用自定义组件。 此外&#xff0c;当将组件映射到JAR中时&#xff0c;需要在web.xml一个特殊条目以指向…

[ACM训练] ACM中巧用文件的输入输出来改写acm程序的输入输出 + ACM中八大输入输出格式...

ACM中巧用文件的输入输出来改写acm程序的输入输出 经常有见大神们使用文件来代替ACM程序中的IO&#xff0c;尤其是当程序IO比较复杂时&#xff0c;可以使自己能够更专注于代码的测试&#xff0c;而不是怎样敲输入。 C/C代码中&#xff1a; 使用 stdio.h 中包含的另一个函…

中断按键c语言程序设计,单片机C语言代码:外部中断,按下中断按键LED不亮,LED1正常亮...

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼* 名称&#xff1a;外部中断* 日期&#xff1a;2013-9-10* 晶振:11.0592MHZ******************************************************************/#include //包含头文件&#xff0c;对IO进行定义&#xff0c;可以选中后右击&…

状态机复合状态 怎么写代码_状态不属于代码

状态机复合状态 怎么写代码Web应用程序中的“状态”是什么&#xff1f; 它是要存储的数据&#xff08;与目的地无关—内存&#xff0c;数据库&#xff0c;文件系统&#xff09;。 应用程序本身不得在代码中存储任何状态。 这意味着您的类应该只包含带有无状态对象的字段。 换句…

c语言均值滤波程序,均值滤波C语言代码实现的一种简单方式

计算均值滤波时&#xff0c;需要每次求数组的和&#xff0c;再求均值&#xff0c;一般先放入一个数组&#xff0c;循环移出最后一个旧的值循环移入新的值一般原来的做法/******************************************************************************//*** param[in] data[…

用户管理实例 之 添加、查询

访问视图先是访问控制器中的方法&#xff0c;在去找跟方法同名的视图&#xff0c;或者指定的视图 这里是用LinQ查询数据库的一张表的数据&#xff0c;在控制器中ViewData存储数据&#xff0c;把此数据&#xff08;一张表&#xff09;在前台页面上显示出来。 控制器中&#xff1…

Java内存体系结构(模型),垃圾回收和内存泄漏

Java内存架构&#xff08;Java内存模型&#xff09; 上面是堆的Java内存模型以及Java虚拟机&#xff08;JVM&#xff09;中运行的任何Java应用程序的PermGen。 还提供了比率&#xff0c;以使您更好地了解如何在每种世代类型之间分配允许的内存。 以上所有内容完全适用于Java 1…

1101. 献给阿尔吉侬的花束(bfs找最短路径)

题目&#xff1a; 1101. 献给阿尔吉侬的花束 - AcWing题库 输入样例&#xff1a; 3 3 4 .S.. ###. ..E. 3 4 .S.. .E.. .... 3 4 .S.. #### ..E.输出样例&#xff1a; 5 1 oop! 思路&#xff1a;bfs宽搜 用队列实现bfs。踢出队列头&#xff0c;并在队列尾插入与对头相关的…

c 编程语言概述,C编程语言概述

C编程语言概述引导语&#xff1a;C的应用范围广泛&#xff0c;具备很强的数据处理能力&#xff0c;以下是百分网小编分享给大家的C编程语言概述&#xff0c;欢迎阅读学习!编程语言概述学习一门新语言的惟一途径就是使用它来编程。对于初学者来说&#xff0c; 编写的第一个程序几…

Linux crontab定时执行任务

基本格式 : *  *  *  *  *  command 分 时 日 月 周 命令 第1列表示分钟1&#xff5e;59 每分钟用*或者 */1表示 第2列表示小时1&#xff5e;23&#xff08;0表示0点&#xff09; 第3列表示日期1&#xff5e;31 第4列表示月份1&#xff5e;12 第5列标识号星期0&…

apache mahout_Apache Mahout:入门

apache mahout最近&#xff0c;我有一个有趣的问题要解决&#xff1a;如何使用自动化对不同来源的文本进行分类&#xff1f; 前一段时间&#xff0c;我读到一个有关该项目以及许多其他文本分析工作的项目– Apache Mahout 。 尽管它不是一个非常成熟的版本&#xff08;当前版本…

硬链接和软连接(符号链接)

硬链接:不同路径的文件指定的是同一个inode硬链接不能跨分区存在硬链接不能链接到目录(要避免循环引用)删除硬链接只会减少文件被硬链接的次数,源文件不会动.软链接:是一个独立的文件,有自己独立的inode&#xff0c;引用的是路径本身,不是inode删除软链接,跟源文件没任何关系软…

基于nbu oj c语言答案,Just oj 2018 C语言程序设计竞赛(高级组)F:Star(结构体排序+最小生成树)...

Time Limit: 1 s Memory Limit: 128 MBProblem Description31世纪&#xff0c;人类世界的科技已经发展到了空前的高度&#xff0c;星际移民&#xff0c;星际旅游早已经不再是问题。人类已经掌握了开发星系的能力。但是&#xff0c;无论发展到何种地步&#xff0c;资源一直…

与JBoss BPM Travel Agency更新了现代BPM数据集成

不久前&#xff0c;我们启动了一个规模较大的JBoss Travel Agency演示项目&#xff0c;以展示JBoss BPM Suite的一些更有趣的功能。 我们提供了一系列视频 &#xff0c;不仅向您展示了如何安装它&#xff0c;项目中各种规则和流程工件的含义&#xff0c;还向您介绍了在实际使用…

c语言中坐标xoy轴在哪里,用C语言在linux下获取鼠标指针的相对位置

1. 关于"/dev/input/mice"相信很多人都用过Linux&#xff0c;也许你发现不管是在X-window下面&#xff0c;还是在Console下面&#xff0c;鼠标都是可以操作的。那么你有没有考虑过这些鼠标都是从哪来的&#xff1f;不错&#xff01;他们都是从"/dev/input/mice&…