首 页 ┆ 源码下载 ┆ IT学院 ┆ 字体下载 ┆ 模板下载 ┆ 源码发布 ┆ 广告合作 ┆ 网站地图 ┆ 虚拟主机 ┆ 中文域名
► 设为首页
► 加入收藏
► 联系我们
源码下载 >> ASP源码 | PHP源码 | ASP.net源码 | JSP源码 | CGI源码 | VC/C++源码 | VB源码 | Delphi源码 | Flash源码
文章学院 >> 网络编程 | 网页设计 | 图形图象 | 数据库 | 服务器 | 网络媒体 | 网络安全 | 操作系统 | 办公软件 | 软件开发 | 黑客知识
字体下载 >> 精制字体 | 非英字体 | 艺术字体 | 著名字体 | 哥特式 | 简单字体 | 手写体 | 节假日 | 图案字体 | 精度像素 | 中文字体
模板下载 >> 企业门户 | 数码网络 | 休闲娱乐 | 影视音乐 | 旅游名胜 | 文化艺术 | 电子商务 | 个性展示 | 登陆导航 | Flash模板
►►您当前的位置:源码园 → IT学院 → 数据库 → ORACLE → 文章内容

Oracle中临时表的深入研究

作者:无从考证  来源:中国软件  发布时间:2007-2-7 11:54:50
 

最近考虑到我们的数据库端写存储过程关于临时表使用的情况,由于我们

 

现在还不清楚数据库端到底是怎么处理的,是否和Sql Server的处理方式相

 

同,是否会存在隐患等等一些问题,为了避免将来不必要的麻烦我做了深

 

入的研究和查看了一些权威的资料,现在和大家共享,希望大家在处理

 

Oracle临时表是注意一下:

 

首先是创建临时表的语法:

CREATE GLOBAL TEMPORARY TABLE table

"(" column datatype [DEFAULT expr] [{ NULL | NOT NULL}]

[, column datatype [DEFAULT expr] [ {NULL | NOT NULL} ]... ")"

ON COMMIT {DELETE | PRESERVE } ROWS ;

 

 

Oracle中的临时表有两种一种是事务级别的临时表它在事务结束的时候自

 

动清空记录,另一种是会话级的它在我们访问数据库是的一个会话结束后

 

自动的清空。关于临时表多用户并行不是问题,一个会话从来不会阻止另

 

一个会话使用临时表。即使“锁定”临时表,一个会话也不会阻止其他会

 

话使用它们的临时表。

 

   如果有在SQL SERVER 和\或sybase中使用临时表的经验,需要主要考

 

虑的不是执行select x,y ,z into #temp from some_table 来创建和装载临时

 

表,而是:

 

1.            对于每一个数据库,创建所有的temp表作为全局临时表。这将作

    

      为应用程序安装的一部分完成,就像创建永久表一样。

 

2.            只要在过程中简单的insert into temp(x,y,z) selelct x,y,z from some_table。

 

只是理解这点,这里的目的不是运行存储过程创建表。在Oracle中这样做

 

不是正确的方法。DDL是一种消耗资源非常大的操作,在运行时尽量不要

 

使用,应用程序需要的临时表应在应用程序安装时创建,而不是在运行时

 

创建。Oracle中的临时表和其他数据库的临时表是相似的,在每个数据库

 

中创建临时表一次,不必在数据库中的每个存储过程中创建一次。临时表

 

总是存在的,他们作为对象存在于数据字典中,并且总是保持为空,直到

 

有会话在其中放入数据。

 

所有我在这里说明如果我们在存储过程中建临时表,每次都建立一个那么

 

我的系统随着用户的操作调用此存储过程,每次多一个这样的表,我们在

 

不知不觉中数据库中的表的数量会越来越多,而我们还不知道会存在很大

 

的隐患的所有说这点不可小视,为了我们的系统能在客户那里平稳、安全

 

的运行我们一定要注意这样的问题。如果不手动Drop 表,临时表还是在数据字典中存在的。


[] [返回上一页] [打 印]
  • 上一篇文章:ORACLE用户自定义备份与恢复笔记
  • 下一篇文章:Oracle SQLCODE/SQLERRM

  • 相关文章:
  • Jsp中调用Oracle存储过程的例子
  • 在Win2000中安装JSP并访问Oracle
  • [图文]Oracle开源PHP的OPAL计划开始
  • JBuilder2005+JBOSS+Oracle9i环境配置
  • JDBC+Hibernate将Blob数据写入Oracle
  • Delphi中对Oracle存取RTF文档(1)
  • 在linux7.1上安装jdk+tomcat+oracle9i 笔记
  • 在linux7.1上安装jdk+tomcat+oracle9i笔记
  • Vmware gsx 2.5+linux+oracle817ops 双机安装手册
  • Oracle 数据库之克隆方法 (for Redhat Linux7.2,原...
  • Oracle发布10g试验版本 扩大对Mac OS X支持
  • [组图]深入研究DNS原理
关于本站 - 网站帮助 - 广告合作 - 下载声明 - 友情连接 - 网站地图 - 源码发布
Copyright © 2003-2009 Ymyasp.Com. All Rights Reserved .
备案序号:粤ICP备07029071号