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

oracle优化--表优化(临时表)

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

oracle优化--表优化(临时表)

一、创建临时表与普通表


SQL> CREATE GLOBAL TEMPORARY TABLE TMP_TEST ON COMMIT PRESERVE ROWS AS SELECT * FROM emp;


Table created.


SQL> select count(0) from TMP_TEST;


  COUNT(0)

----------

14


SQL> CREATE GLOBAL TEMPORARY TABLE TMP_TEST1 ON COMMIT DELETE ROWS AS SELECT * FROM emp;


Table created.


SQL> select count(0) from TMP_TEST1;


  COUNT(0)

----------

 14


SQL> create table tmp_test2 as select * from emp;


Table created.


SQL> select count(0) from TMP_TEST2;


  COUNT(0)

----------

14


--由于创建tmp_test2为ddl,所以TMP_TEST1数据被清空;


SQL> select count(0) from TMP_TEST1;


  COUNT(0)

----------

0


--关闭会话重新打开,TMP_TEST数据也被清空


SQL> select count(0) from TMP_TEST;


  COUNT(0)

----------

0


二、分别对副本表进行增删改操作,对比性能,可以发现以下差别:


新增时:临时表的cr=8,普通表cr=11

修改时:临时表的cr=3,cost=2;普通表cr=7,cost=3

删除时:临时表的cr=3,cost=2;普通表cr=7,cost=3


所以临时表如果作为运算中间表做增删改运算时性能皆比普通表高


SQL> insert into SCOTT.TMP_TEST SELECT * FROM SCOTT.emp;


14 rows created.


Rows (1st) Rows (avg) Rows (max)  Row Source Operation

---------- ---------- ----------  ---------------------------------------------------

         0          0          0  LOAD TABLE CONVENTIONAL  ( cr=8  pr=0 pw=0 time=548 us)

        14         14         14   TABLE ACCESS FULL EMP (cr=7 pr=0 pw=0 time=64 us cost=3 size=1218 card=14)


SQL> insert into SCOTT.TMP_TEST1 SELECT * FROM SCOTT.emp;


14 rows created.


Rows (1st) Rows (avg) Rows (max)  Row Source Operation

---------- ---------- ----------  ---------------------------------------------------

         0          0          0  LOAD TABLE CONVENTIONAL  ( cr=8 pr=0 pw=0 time=566 us)

        14         14         14   TABLE ACCESS FULL EMP (cr=7 pr=0 pw=0 time=63 us cost=3 size=1218 card=14)


SQL> insert into SCOTT.TMP_TEST2 SELECT * FROM SCOTT.emp;


14 rows created.


Rows (1st) Rows (avg) Rows (max)  Row Source Operation

---------- ---------- ----------  ---------------------------------------------------

         0          0          0  LOAD TABLE CONVENTIONAL  ( cr=11 pr=2 pw=0 time=784 us)

        14         14         14   TABLE ACCESS FULL EMP (cr=7 pr=0 pw=0 time=31 us cost=3 size=1218 card=14)


SQL> delete from SCOTT.TMP_TEST where SAL<=2500;


9 rows deleted.


Rows (1st) Rows (avg) Rows (max)  Row Source Operation

---------- ---------- ----------  ---------------------------------------------------

         0          0          0  DELETE  TMP_TEST ( cr=3 pr=0 pw=0 time=125 us)

         9          9          9   TABLE ACCESS FULL TMP_TEST (cr=3 pr=0 pw=0 time=50 us cost=2 size=117 card=9)


SQL> delete from SCOTT.TMP_TEST1 where SAL<=2500;


9 rows deleted.


Rows (1st) Rows (avg) Rows (max)  Row Source Operation

---------- ---------- ----------  ---------------------------------------------------

         0          0          0  DELETE  TMP_TEST1 ( cr=3 pr=0 pw=0 time=161 us)

         9          9          9   TABLE ACCESS FULL TMP_TEST1 (cr=3 pr=0 pw=0 time=77 us cost=2 size=117 card=9)


SQL> delete from SCOTT.TMP_TEST2 where SAL<=2500;


9 rows deleted.


Rows (1st) Rows (avg) Rows (max)  Row Source Operation

---------- ---------- ----------  ---------------------------------------------------

         0          0          0  DELETE  TMP_TEST2 ( cr=7 pr=0 pw=0 time=105 us)

         9          9          9   TABLE ACCESS FULL TMP_TEST2 (cr=7 pr=0 pw=0 time=13 us cost=3 size=117 card=9)


SQL> update SCOTT.TMP_TEST set sal=sal+100;


5 rows updated.


Rows (1st) Rows (avg) Rows (max)  Row Source Operation

---------- ---------- ----------  ---------------------------------------------------

         0          0          0  UPDATE  TMP_TEST ( cr=3 pr=0 pw=0 time=132 us)

         5          5          5   TABLE ACCESS FULL TMP_TEST (cr=3 pr=0 pw=0 time=46 us cost=2 size=65 card=5)


SQL> update SCOTT.TMP_TEST1 set sal=sal+100;


5 rows updated.


Rows (1st) Rows (avg) Rows (max)  Row Source Operation

---------- ---------- ----------  ---------------------------------------------------

         0          0          0  UPDATE  TMP_TEST1 ( cr=3 pr=0 pw=0 time=132 us)

         5          5          5   TABLE ACCESS FULL TMP_TEST1 (cr=3 pr=0 pw=0 time=34 us cost=2 size=65 card=5)


SQL> update SCOTT.TMP_TEST2 set sal=sal+100;


5 rows updated.


Rows (1st) Rows (avg) Rows (max)  Row Source Operation

---------- ---------- ----------  ---------------------------------------------------

         0          0          0  UPDATE  TMP_TEST2 ( cr=7 pr=0 pw=0 time=69 us)

         5          5          5   TABLE ACCESS FULL TMP_TEST2 (cr=7 pr=0 pw=0 time=15 us cost=3 size=65 card=5)


免责声明:

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

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

oracle优化--表优化(临时表)

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

下载Word文档

猜你喜欢

MySQL优化临时表使用

MySQL优化临时表的使用可以从以下几个方面进行:选择合适的存储引擎:MySQL支持多种存储引擎,如InnoDB、MyISAM等。对于临时表,建议使用InnoDB存储引擎,因为它支持行级锁定,事务处理和更高级别的数据完整性保证。合理设置临时
MySQL优化临时表使用
2024-10-20

MySQL查询优化临时表

【理论分析】MySQL在执行SQL查询时可能会用到临时表,一般情况下,用到临时表就意味着性能较低。临时表存储MySQL临时表分为“内存临时表”和“磁盘临时表”,其中内存临时表使用MySQL的MEMORY存储引擎,磁盘临时表使用MySQL的MyISAM存储引擎;
2019-09-24

索引在Oracle中处理临时表的优化

在Oracle中处理临时表时,可以通过以下几种方式来优化索引的使用:考虑使用局部索引:对于临时表,如果只需要在某些列上进行索引操作,可以考虑使用局部索引而不是全局索引。局部索引只会在指定列上创建索引,可以减少索引占用的空间和提高查询性能。考
索引在Oracle中处理临时表的优化
2024-08-15

临时表在SQL优化中的作用

临时表,顾名思义就只是临时使用的一张表,一种是本地临时表,只能在当前查询页面使用,新开查询是不能使用它的,一种是全局临时表,不管开多少查询页面均可使用。
SQL优化作用2024-12-03

变量在Oracle数据库临时表使用中的优化

在Oracle数据库中,临时表(Temporary Table)是一种用于存储临时数据的特殊表,它们通常被用于在会话期间存储中间结果或临时数据。在使用临时表时,为了提高查询性能和减少资源消耗,可以考虑以下优化方法:尽量避免在临时表中创建索引
变量在Oracle数据库临时表使用中的优化
2024-08-23

MySQL 临时表的原理以及优化方法

目录1 临时表2 union临时表优化3 group by临时表优化1 临时IcztZkHlyx表sort buffer、内存临时表和join buffer,这三个数据结构都是用来存放语句执行过程中的中间数据,以辅助SQL语句的执行的。其
2022-08-22
2024-04-02

如何优化MySQL表?

优化 MySQL 表是提高数据库性能和效率的关键一步。通过采用有效的优化技术,您可以提高查询执行速度、降低存储要求并优化资源利用率。本文探讨了优化 MySQL 表的各种策略和最佳实践,使您能够最大限度地提高数据库驱动的应用程序的性能。在本
2023-10-22

索引对Oracle跨表查询的优化

在Oracle数据库中,跨表查询通常涉及多个表之间的连接操作,因此需要对查询进行优化以提高查询性能。以下是一些优化跨表查询的方法:索引优化:确保在连接条件字段上建立索引,这样可以加快连接操作的速度。特别是在大表上进行连接操作时,索引会大大减
索引对Oracle跨表查询的优化
2024-08-16

正则表达式的运行时优化

php小编柚子为大家介绍正则表达式的运行时优化。正则表达式是一种用于字符串匹配和处理的强大工具,但在处理大规模数据时可能会导致性能问题。为了提高正则表达式的执行效率,我们可以采取一些优化策略,如使用惰性匹配、避免使用回溯、使用更精确的匹配模
正则表达式的运行时优化
2024-02-11

sql临时表的优缺点是什么

SQL临时表的优点包括:临时表可以提高查询性能:通过将查询结果存储在临时表中,可以减少查询的复杂性和计算量,从而提高查询性能。临时表可以存储中间结果:在复杂的查询中,可以使用临时表来存储中间结果,以便后续查询使用。临时表可以提供更好的可读性
sql临时表的优缺点是什么
2024-04-09

DB2 ORACLE 临时表创建

一、临时表     临时表(TEMPORARY TABLE)通常应用在需要定义临时集合的场合。但是,在大部分需要临时集合的时候,我们根本就不需要定义临时表。当我们在一条SQL语句中只使用一次临时集合时,我们可以使用嵌套表表达式来定义临时集合;当我们在一条SQL
DB2 ORACLE 临时表创建
2015-09-25

编程热搜

目录