1、前言
目前所有使用oracle作为数据库支撑平台的应用,大部分数据量比较庞大的系统,即表的数据量一般情况下都是在百万级以上的数据量。
当然在oracle中创建分区是一种不错的选择,但是当你发现你的应用有多张表关联的时候,并且这些表大部分都是比较庞大,而你关联的时候发现其中的某一
张或者某几张表关联之后得到的结果集非常小并且查询得到这个结果集的速度非常快,那么这个时候我考虑在oracle中创建“临时表”。
我对临时表的理解:在oracle中创建一张表,这个表不用于其他的什么功能,主要用于自己的软件系统一些特有功能才用的,而当你用完之后表中的数据就没
用了。oracle的临时表创建之后基本不占用表空间,如果你没有指定临时表(包括临时表的索引)存放的表空的时候,你插入到临时表的数据是存放在
oracle系统的临时表空间中(temp)。
2、临时表的创建
创建oracle临时表,可以有两种类型的临时表:会话级的临时表和事务级的临时表。
1)会话级的临时表因为这这个临时表中的数据和你的当前会话有关系,当你当前session不退出的情况下,临时表中的数据就还存在,而当你退出当前
session的时候,临时表中的数据就全部没有了,当然这个时候你如果以另外一个session登陆的时候是看不到另外一个session中插入到临时
表中的数据的。即两个不同的session所插入的数据是互不相干的。当某一个session退出之后临时表中的数据就被截断(truncate
table,即数据清空)了。会话级的临时表创建方法:
<!---->
create
global
temporary
table
table_name(col1 type1,col2 type2...)
on
commit
preserve rows;
举例:
<!---->
create
global
temporary
table
student(stu_id
number
(
5
),class_id
number
(
5
),stu_name
varchar2
(
8
),stu_memo
varchar2
(
200
))
on
commit
preserve rows ;
2)事务级临时表是指该临时表与事务相关,当进行事务提交或者事务回滚的时候,临时表中的数据将自行被截断,其他的内容和会话级的临时表的一致(包括退出session的时候,事务级的临时表也会被自动截断)。事务级临时表的创建方法:
<!---->
create
global
temporary
table
table_name(col1 type1,col2 type2...)
on
commit
delete
rows;
举例:
<!---->
create
global
temporary
table
classes(class_id
number
(
5
),class_name
varchar2
(
8
),class_memo
varchar2
(
200
))
on
commit
delete
rows ;
3)、两种不通类型的临时表的区别:语法上,会话级临时表采用on commit preserve rows而事务级则采用on
commit delete
rows;用法上,会话级别只有当会话结束临时表中的数据才会被截断,而且事务级临时表则不管是commit、rollback或者是会话结束,临时表中
的数据都将被截断。
3、例子:
1)、会话级
(session关闭掉之后数据就没有了,当commit的时候则数据还在,当rollback的时候则数据也是一样被回滚):
<!---->
insert
into
student(stu_id,class_id,stu_name,stu_memo)
values
(
1
,
1
,
''
张三
''
,
''
福建
''
);
insert
into
student(stu_id,class_id,stu_name,stu_memo)
values
(
2
,
1
,
''
刘德华
''
,
''
福州
''
);
insert
into
student(stu_id,class_id,stu_name,stu_memo)
values
(
3
,
2
,
''
s.h.e
''
,
''
厦门
''
);sql
>
select
*
from
student ;
stu_id class_id stu_name stu_memo
1
1
张三 福建2
1
刘德华 福州3
2
s.h.e 厦门4
2
张惠妹 厦门
sql
>
commit
;
commit
complete
sql
>
select
*
from
student ;
stu_id class_id stu_name stu_memo
1
1
张三 福建2
1
刘德华 福州3
2
s.h.e 厦门4
2
张惠妹 厦门
sql
>
insert
into
student(stu_id,class_id,stu_name,stu_memo)
values
(
4
,
2
,
''
张惠妹
''
,
''
厦门
''
);
1
row inserted
sql
>
select
*
from
student ;
stu_id class_id stu_name stu_memo
1
1
张三 福建2
1
刘德华 福州3
2
s.h.e 厦门4
2
张惠妹 厦门4
2
张惠妹 厦门
sql
>
rollback
;
rollback
complete
sql
>
select
*
from
student ;
stu_id class_id stu_name stu_memo
1
1
张三 福建2
1
刘德华 福州3
2
s.h.e 厦门4
2
张惠妹 厦门
分享到:
相关推荐
本文将深入探讨如何利用Oracle临时表来优化查询速度,并提供具体的实现策略。 #### 一、Oracle临时表的基本概念及应用场景 Oracle临时表是一种特殊类型的表,它们主要用于存储临时数据,这些数据通常在一次会话...
本文将详细介绍Oracle临时表的创建方法、使用场景以及优缺点,帮助读者更好地理解和运用这一特性。 #### 二、Oracle临时表概述 Oracle临时表是一种特殊的表,用于存储临时数据,通常用于事务处理或特定会话期间的...
Oracle 临时表空间不足和批处理缓慢问题探讨 本文探讨了 Oracle 临时表空间不足和批处理缓慢问题的原因和解决方法。通过分析和测试,发现了问题的根源在于应用逻辑方面,具体来说是 SQL 语句的编写问题。通过编写...
理解Oracle临时表的概念及其工作原理对于优化应用程序的性能至关重要。合理使用临时表可以帮助提高数据处理的速度,同时减少不必要的资源消耗。无论是事务临时表还是会话临时表,都有各自的应用场景和限制。在实际...
Oracle 临时表空间是Oracle...总之,理解并正确使用Oracle临时表空间是确保数据库高效运行的关键。通过对临时表空间的合理配置和管理,可以有效地提升数据库的响应速度,降低系统资源消耗,从而优化整体的数据库性能。
通过理解和优化临时表空间,可以显著提升Oracle数据库的性能,尤其是在处理大数据量和复杂查询时。因此,对于数据库管理员来说,了解并掌握这部分知识至关重要,能够帮助他们在日常工作中更有效地管理和维护数据库...
Oracle临时表是数据库管理系统...通过学习和理解Oracle临时表,我们可以更有效地管理短暂的、会话级别的数据,优化数据库性能,提升应用的响应速度。在实际工作中,适时使用临时表能为我们的数据库操作带来极大的便利。
4. **子查询和临时表**:子查询可能会导致性能问题,书中的案例可能会演示如何通过重写查询、使用WITH子句(公共表表达式)或者临时表来优化子查询。 5. **分页查询**:在大数据量场景下,高效的分页查询必不可少。...
#### 二、Oracle临时表概述 临时表是Oracle提供的一种特殊类型的表,用于存储临时数据。它们通常用于执行复杂的计算任务或暂存中间结果,以减少对主表的访问次数,从而提升整体性能。根据生命周期的不同,临时表...
本文重点分析Oracle数据库索引及临时表在查询中的应用,并探讨了基于索引使用SQL语句进行数据库效率优化的几种实现方法。 在Oracle数据库中,索引的合理运用能够显著提升查询速度,减少I/O操作,避免磁盘排序。通常...
本文将围绕如何提升Oracle数据库的查询统计速度进行深入探讨,并结合实际应用场景给出具体的优化建议。 #### 一、理解Oracle数据库查询统计的基本概念 1. **查询统计**:指的是对数据库中的数据进行筛选、排序、...
6. **减少排序和临时表**:不必要的ORDER BY和GROUP BY操作会增加排序开销。优化查询结构,尽量减少排序需求,或者利用索引进行排序。 7. **查询优化器**:理解CBO(Cost-Based Optimizer)的工作原理,学习如何...
"Oracle查询优化改写"是一个专业领域,旨在通过调整SQL语句的结构和逻辑,提高查询速度,降低资源消耗,从而提升整体系统性能。本文将深入探讨这个主题,结合大量实际案例,提供一系列实用的技巧和方法。 首先,...
- **临时表空间(Temporary Tablespace)**:用于存储临时数据,如排序操作过程中产生的临时表。 2. **段(Segment)**:段是表空间中用于存储特定类型数据的对象集合,包括表段、索引段等。 - **表段(Table Segment)...
- **非理想情况:** 如果排序数据超过了排序区的大小限制,则Oracle不得不将这部分数据转移到磁盘上的临时表空间进行排序,这将大大降低性能。 **2.3 调整排序区大小的方法** - **初始化参数SORT_AREA_SIZE:** ...
Oracle查询优化是数据库管理中的重要环节,它直接关系到数据库的性能和响应速度。针对Oracle数据库的查询优化,本文件提供了丰富的技巧和案例分析,以帮助读者深入理解优化原理,并能在实际工作中学以致用。 首先,...
总结来说,Oracle的临时表是数据库管理中的一种优化策略,特别是在处理复杂查询和大量数据时,通过合理使用临时表,可以优化性能,提高系统的响应速度,同时减少了对数据库物理存储的压力。在设计数据库解决方案时,...
SQL调优主要通过分析查询执行计划,优化查询语句,减少全表扫描,提高查询效率。索引的合理设计可以显著提升数据检索速度,但过多的索引可能会影响写操作性能。存储优化包括选择合适的表空间、段和分区策略,以及...
2. **缓存结果**:对于重复计算的结果,可以考虑使用临时表或缓存。 3. **触发器谨慎使用**:触发器可能导致隐式事务和性能问题,尽量用业务逻辑替代。 五、其他优化技巧 1. **统计信息更新**:定期收集和更新表的...
考虑用JOIN或临时表替换子查询,或使用关联子查询和存在子查询的优化策略。 4. **聚合函数和分组**:使用GROUP BY和HAVING子句时,尽量减少分组列的数量,并考虑预计算或汇总表。对于大量数据,物化视图可以提供...