- 浏览: 1542788 次
- 性别:
- 来自: 上海
文章分类
- 全部博客 (532)
- 软件设计师 (7)
- PSP (5)
- NET MD (9)
- Hibernate (8)
- DIY (51)
- Work (43)
- GAME (24)
- 未分类 (44)
- iPod (6)
- MySQL (39)
- JSP (7)
- 日语能力考试 (36)
- 小说 (4)
- 豆包网 (23)
- 家用电脑 (7)
- DB2 (36)
- C/C++ (18)
- baby (9)
- Linux (13)
- thinkpad (23)
- OA (1)
- UML (6)
- oracle (24)
- 系统集成 (27)
- 脑梗塞 (6)
- 车 (8)
- MainFrame (8)
- Windows 7 (13)
- 手机 (8)
- git (12)
- AHK (2)
- COBOL (2)
- Java (9)
最新评论
-
安静听歌:
... ...
UUID做主键,好还是不好?这是个问题。 -
lehehe:
http://www.haoservice.com/docs/ ...
天气预报 -
lehehe:
[url http://www.haoservice.com/ ...
天气预报 -
liubang201010:
监控TUXEDO 的软件推荐用这个,专业,权威.并能提供报警和 ...
(转载)Tuxedo中间件简介 -
tinkame:
Next[j] =-1 当j=0时;=Max{k|0<k ...
KMP字符串模式匹配详解
近年我做的项目中较少使用临时表Temporary Table ,其实 Temp Table 还是可以有比较广泛的应用的。 Temp Table 的特点: (1) 多用户操作的独立性:对于使用同一张临时表的不同用户,ORACLE都会分配一个独立的 Temp Segment,这样就避免了多个用户在对同一张临时表操作时发生交叉,从而保证了多个用户操作的并发性和独立性; Temp Table 数据的时效性: (1)On Commit Delete Rows: 数据在 Transaction 期间有效,一旦COMMIT后,数据就被自动 TRUNCATE 掉了; SQL> CREATE GLOBAL TEMPORARY TABLE QCUI_Temp_Trans 表已创建。 SQL> INSERT INTO QCUI_Temp_Trans 已创建4行。 SQL> SELECT * FROM QCUI_Temp_Trans; DEPTID DEPTNAME SQL> commit; 提交完成。 SQL> SELECT * FROM QCUI_Temp_Trans; 未选定行 (2)On Commit Preserve Rows :数据在 Session 期间有效,一旦关闭了Session 或 Log Off 后,数据就被 ORACLE 自动 Truncate 掉。 SQL> CREATE GLOBAL TEMPORARY TABLE QCUI_Temp_Sess 表已创建。 SQL> Select * from QCUI_Temp_Sess; DEPTID DEPTNAME SQL> exit C:\Documents and Settings\QCUI>sqlplus sqltrainer@ibm SQL> SELECT * FROM QCUI_Temp_Sess; 未选定行 注:这里要说明的是,ORACLE Truncate 掉的数据仅仅是分配给不同 Session 或 Transaction的 Temp Segment 上的数据,而不是将整张表数据 TRUNCATE 掉。 Temp Table 的应用: Temp Table 就我理解而言,主要有两方面应用。 对于一个电子商务类网站,不同消费者在网站上购物,就是一个独立的 SESSION,选购商品放进购物车中,最后将购物车中的商品进行结算。也就是说,必须在整个SESSION期间保存购物车中的信息。同时,还存在有些消费者,往往最终结账时放弃购买商品。如果,直接将消费者选购信息存放在最终表(PERMANENT)中,必然对最终表造成非常大的压力。 Temp Table 存放在哪儿? Temp Table 并非存放在用户的表空间中,而是存放在 Schema 所指定的临时表空间中。 SQL> Select Table_Name, Tablespace_Name TABLE_NAME TABLESPACE_NAME 可见这两张临时表并未存放在用户的表空间中。 SQL> SELECT UserName, Default_Tablespace def_ts, Temporary_Tablespace temp_ts USERNAME DEF_TS TEMP_TS SQL> connect system/manager@ibm 已连接。 SQL> alter tablespace temp offline; 表空间已更改。 SQL> connect sqltrainer/sqltrainer@ibm 已连接。 SQL> INSERT INTO QCUI_Temp_Sess INSERT INTO QCUI_Temp_Sess ERROR 位于第 1 行: 对 Temp Table 的 DML 操作是否不产生 Redo Log ? 尽管对临时表的DML操作速度比较快,但同样也是要产生 Redo Log 的,只是同样的DML语句,比对 PERMANENT 的DML 产生的Redo Log 少。 SQL> Set AutoTrace On SQL> CREATE GLOBAL TEMPORARY TABLE QCUI_Temp_Sess_AllObj 表已创建。 SQL> INSERT INTO QCUI_Temp_Sess_AllObj 已创建21839行。 Statistics SQL> CREATE TABLE QCUI_ALL_OBJECTS 表已创建。 SQL> INSERT INTO QCUI_All_Objects 已创建21839行。 Statistics
(2) 数据的临时性:既然是临时表,顾名思义,存放在该表中的数据是临时性的。ORACLE根据你创建临时表时指定的参数(On Commit Delete Rows / On Commit Preserve Rows),自动将数据TRUNCATE掉。
2 ON COMMIT DELETE ROWS
3 AS
4 SELECT * FROM t_Department;
2 SELECT * FROM t_Dept;
---------- --------------------
101 销售部
201 财务部
301 货运部
401 采购部
2 ON COMMIT PRESERVE ROWS
3 AS
4 SELECT * FROM t_Department;
---------- --------------------
101 销售部
301 货运部
401 采购部
201 财务部
因此,对于这种案例,就可以采用创建临时表( ON COMMIT PRESERVE ROWS )的方法来解决。数据只在 SESSION 期间有效,对于结算成功的有效数据,转移到最终表中后,ORACLE自动TRUNCATE 临时数据;对于放弃结算的数据,ORACLE 同样自动进行 TRUNCATE ,而无须编码控制,并且最终表只处理有效订单,减轻了频繁的DML的压力。
Temp Table 的另一个应用,就是存放数据分析的中间数据。
2 From User_Tables
3 Where Table_Name Like 'QCUI%';
------------------------------ ------------------------------
QCUI_TEMP_SESS
QCUI_TEMP_TRANS
用户 SQLTRAINER 的临时表空间是 TEMP , 用户创建的临时表是存放在TEMP表空间中的。下面来证明
2 FROM User_Users;
----------------------------- ------------------ ----------
SQLTRAINER ts_ORASQLTraining TEMP
2 SELECT * FROM t_Department;
*
ORA-01542: 表空间'TEMP'脱机,无法在其中分配空间
2 ON COMMIT PRESERVE ROWS
3 AS
4 SELECT * FROM All_Objects;
2 SELECT * FROM All_Objects;
---------------------------------------------------------
……
168772 redo size
……
2 AS
3 SELECT * FROM All_Objects
4 WHERE 1 = 0;
2 SELECT * FROM ALL_Objects;
----------------------------------------------------------
……
2439044 redo size
……
发表评论
-
(转)【性能优化】ORACLE数据库性能优化概述
2010-10-28 10:37 1322原文:http://space.itpub.net ... -
(转)【sql调优】系统信息统计
2010-10-28 10:36 1167原文:http://space.itpub.net/?uid- ... -
(转)【SQL 性能优化】参数设置(优化器)
2010-10-28 10:34 1720原文:http://space.itpub.net/226 ... -
(转)sqlplus中如何插入blob数据?
2010-09-01 09:39 1893http://www.itpub.net/viewthre ... -
(转)CSV文本数据如何导入oracle(实例)
2010-08-31 13:42 1735http://blog.csdn.net/senmon20 ... -
(转)一般导入数据到Oracle有几种方法!这可是经验之谈哦!
2010-08-31 13:40 2299http://hi.baidu.com/will0690/ ... -
(转)如何将TXT,EXCEL或CSV数据导入ORACLE到对应表中
2010-08-31 13:39 5640如何将TXT,EXCEL或CSV数据导入ORACL ... -
(转)oracle 查看数据库连接备忘
2010-08-19 15:28 1066http://yezi.iteye.com/blog/ ... -
(转)从问题入手帮你解决Oracle杀死死锁进程
2010-08-19 15:26 1619http://dev.firnow.com/cou ... -
(转)oracle临时表的用法总结
2010-07-22 09:20 1406http://blog.csdn.net/wyzxg/ar ... -
(转)VC下ADO访问远程ORACLE数据库
2010-07-13 15:39 4520http://blog.csdn.net/pku2009/ ... -
(转)Oracle版本区别
2010-03-29 14:23 1758http://blog.csdn.net/pengyouc ... -
(转)Oracle数据库11g版本介绍
2010-03-29 14:18 1346http://www.oracle.com/lang/cn ... -
Oracle平台应用数据库系统的设计与开发
2009-12-31 11:14 983http://tech.163.com/05/0607/1 ... -
oracle 购买方式
2009-12-16 16:38 5631http://blog.chinaunix.net/u ... -
Oracle标准版和企业版的区别
2009-12-16 16:36 4622http://blog.chinaunix.net/u ... -
oracle 报价
2009-12-16 16:35 3004http://www.rozsoft.com/html/fxc ... -
Oracle10g New Feature:闪回恢复区空间管理
2009-11-26 13:32 1661Oracle10g New Feature:闪回恢复区空间管理 ... -
Oracle数据库设计开发阶段性能优化策略
2009-11-25 15:16 1206http://flysen.cn/a/data/orle/ ... -
oracle database Documentation Library
2009-11-25 14:43 251510g Release 2 (10.2) ...
相关推荐
### Oracle 临时表用法详解 #### 一、背景与问题描述 在处理数据库操作时,经常遇到因数据量庞大而导致处理效率降低的问题。...同时,需要注意Oracle临时表的一些局限性,以便在实际应用中做出合理的决策。
临时表本质上是一种cache的表现形式,Oracle的临时表都是事先建好的,一旦用了临时表,存放的是和本会话相关的数据,没有人会傻乎乎地用临时表来保存本应该共享的数据。 with子查询实际上也是用了临时表,...
Oracle 临时表空间不足和批处理缓慢问题探讨 本文探讨了 Oracle 临时表空间不足和批处理缓慢问题的原因和解决方法。通过分析和测试,发现了问题的根源在于应用逻辑方面,具体来说是 SQL 语句的编写问题。通过编写...
Oracle 临时表是一种特殊的表结构,它可以在数据库中临时存储数据,用于实现一些特定的应用场景。下面是 Oracle 临时表的详细知识点: 创建临时表 创建临时表的语法为: ``` CREATE GLOBAL TEMPORARY TABLE table ...
需要注意的是,与SQL Server和Sybase等其他数据库系统相比,Oracle中不应在运行时动态创建临时表,而应在应用程序安装时创建。DDL操作(如创建表)开销较大,应尽量避免在运行时执行。 总结来说,Oracle的临时表...
理解Oracle临时表的概念及其工作原理对于优化应用程序的性能至关重要。合理使用临时表可以帮助提高数据处理的速度,同时减少不必要的资源消耗。无论是事务临时表还是会话临时表,都有各自的应用场景和限制。在实际...
Oracle 临时表空间是Oracle...总之,理解并正确使用Oracle临时表空间是确保数据库高效运行的关键。通过对临时表空间的合理配置和管理,可以有效地提升数据库的响应速度,降低系统资源消耗,从而优化整体的数据库性能。
本篇文章将深入探讨如何在Oracle存储过程中使用临时表,包括会话级临时表和事务级临时表。 ### 会话级临时表 会话级临时表(Session-Level Temporary Tables)只在创建它的会话内可见,并且在会话结束时自动删除。...
临时表的应用 1)、当某一个SQL语句关联的表在2张及以上,并且和一些小表关联。可以采用将大表进行分拆并且得到比较小的结果集合存放在临时表中。 2)、程序执行过程中可能需要存放一些临时的数据,这些数据在整个...
Oracle临时表是数据库管理系统...通过学习和理解Oracle临时表,我们可以更有效地管理短暂的、会话级别的数据,优化数据库性能,提升应用的响应速度。在实际工作中,适时使用临时表能为我们的数据库操作带来极大的便利。
临时表在Oracle数据库中的应用广泛,例如在报表生成、数据转换、中间结果计算等场景,尤其是在处理大量临时数据且不需要长期保存的情况下,它们提供了高效且安全的解决方案。理解并熟练掌握临时表的使用对于优化...
在Oracle数据库系统中,表空间(Tablespace)是存储数据对象(如表、索引、视图等)的逻辑单位,而临时表空间(Temporary Tablespace)则用于存储临时数据,比如排序或联接操作产生的中间结果。创建和管理表空间及...
#### 二、Oracle临时表概述 临时表是Oracle提供的一种特殊类型的表,用于存储临时数据。它们通常用于执行复杂的计算任务或暂存中间结果,以减少对主表的访问次数,从而提升整体性能。根据生命周期的不同,临时表...
### Oracle特性临时表详解 #### 一、临时表概述 在Oracle数据库中,临时表是一种特殊类型的表,它主要用于存储那些仅对当前会话或事务有意义的数据。与普通表不同的是,临时表的数据不会持久化存储,而是根据特定...
### Oracle优化:提升查询速度与临时表应用 在当前众多基于Oracle数据库的应用系统中,尤其是一些处理大量数据(通常为百万级别以上)的系统,提高查询效率是至关重要的任务之一。本文将深入探讨如何利用Oracle临时...
本篇文章将深入探讨Oracle临时表的使用,并通过一个使用游标(CURSOR)返回结果集的例子来进一步理解其用法。 首先,让我们了解如何创建Oracle临时表。临时表的创建语法与普通表类似,但我们需要使用`GLOBAL ...
然而,当排序区的空间不足时,Oracle会将超出内存容量的临时数据存储到临时表空间中。 临时表空间在数据库操作中扮演着关键角色,尤其是在处理复杂查询和大型数据集时。虽然看似只是临时存储,但实际上它对数据库...
### 一个选查询后插入到一个临时表的Oracle函数 #### 概述 在Oracle数据库环境中,函数是一种非常有用的数据库对象,它允许开发者封装复杂的逻辑并返回特定的结果。本文将详细解析一个特定的Oracle函数——`NS_...
本文档将深入探讨如何在Oracle中创建临时表空间,并介绍一款方便的一键导入、导出工具。 首先,我们来看如何创建临时表空间。在Oracle中,创建临时表空间的SQL语句通常如下: ```sql CREATE TEMPORARY TABLESPACE ...
4. Oracle临时表空间满的问题:当临时表空间的磁盘空间被全部占用后,可能会出现错误消息,例如“ORA-1652: unable to extend temp segment by %s in tablespace %s”。这会导致用户无法完成如排序、并行查询等操作...