`
omega_wu
  • 浏览: 12484 次
  • 来自: ...
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

如何在oracle中用SQL创建临时表?

阅读更多

---------------------------------------------------------------  
 
是TEMPORARY  
CREATE  GLOBAL  TEMPORARY  TABLE  flight_schedule  (  
     startdate  DATE,    
     enddate  DATE,    
     cost  NUMBER)  
 
---------------------------------------------------------------  
 
create  proecdure  name_pro  
as  
str  varchar2(100);  
begin  
str:='CREATE  GLOBAL  TEMPORARY  TABLE  TABLENAME  ON  COMMIT  PRESERVE  ROWS  as  select  *  from  others_table';  
execute  immediate  str;  
end;  
/

深入研究:
 
首先是创建临时表的语法:

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中,可以创建以下两种临时表:

  1) 会话特有的临时表

  CREATE GLOBAL TEMPORARY ( )

  ON COMMIT PRESERVE ROWS;

  2) 事务特有的临时表

  CREATE GLOBAL TEMPORARY ( )

  ON COMMIT DELETE ROWS;

  CREATE GLOBAL TEMPORARY TABLE MyTempTable

  所建的临时表虽然是存在的,但是如果insert 一条记录然后用别的连接登上去select,记录是空的。  

  --ON COMMIT DELETE ROWS 说明临时表是事务指定,每次提交后ORACLE将截断表(删除全部行)

  --ON COMMIT PRESERVE ROWS 说明临时表是会话指定,当中断会话时ORACLE将截断表。 


 
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中用Rowid查找和删除表中的重复记录

    ### Oracle中用Rowid查找和删除表中的重复记录 在Oracle数据库管理中,处理重复记录是一项常见的需求,尤其是在数据量较大的情况下。本文将详细介绍如何利用Rowid这一特性来有效地查找和删除表中的重复记录。 ####...

    oracle数据库移植文件

    该用户的默认表空间设置为`udisk`,临时表空间为`temp`。随后,授予了该用户一系列必要的权限,如`CONNECT`、`CREATE TABLE`、`UNLIMITED TABLESPACE`等,其中`EXP_FULL_DATABASE`和`IMP_FULL_DATABASE`允许用户对...

    SQL 语句 将一个表中用特殊字符分割的字段转换成多行数据.docx

    函数返回一个临时表 `@temp`,其中包含分割后的结果。 ```sql CREATE FUNCTION [dbo].[StringSplit] ( @ttstring NVARCHAR(MAX), @separator CHAR ) RETURNS @temp TABLE ( Item NVARCHAR(50) ) AS ...

    Oracle SQL高级编程(资深Oracle专家力作,OakTable团队推荐)--随书源代码

    作者通过总结各自多年的软件开发和教学培训经验,与大家分享了掌握Oracle SQL所独有的丰富功能的技巧所在,内容涵盖SQL执行、联结、集合、分析函数、子句、事务处理等多个方面。读者可以学习到以下几个方面的技巧:...

    Oracle中用一张表的字段更新另一张表的字段

    在Oracle数据库中,当需要将一个表的字段值更新到另一个表时,通常可以使用`MERGE INTO`语句来实现。`MERGE INTO`是一个非常强大的...对于更复杂的情况,可能需要结合其他数据库操作,如临时表、游标或存储过程来实现。

    Oracle+创建删除用户.pdf

    表空间在Oracle中用于存储数据库对象,如表、索引等。创建临时表空间用于存储临时数据,例如: ```sql CREATE TEMPORARY TABLESPACE zfmi_temptempfile 'D:\oracle\oradata\zfmi\zfmi_temp.dbf'size 32mautoextend ...

    java操作Oracle数据库——ARRAY、TABLE类型批量入库

    ARRAY类型在Oracle中用于存储固定大小的数组,而TABLE类型则更灵活,可以存储变长的行集合,类似于临时表。这两种数据类型在处理大量数据时非常有用,因为它们避免了多次单条插入操作,提升了效率。 在Java中,我们...

    ORACLE9i_优化设计与系统调整

    §9.4.4 临时表空间设计规划 100 §9.4.5 数据文件和日志文件在不同磁盘上 101 §9.5 数据库物理设计 101 §9.5.1 定量估计 101 §9.5.2 表空间与数据文件 102 §9.5.3 物理设计原则 103 §9.5.4 数据库物理设计内容...

    公交线路查询算法与实现PPT学习教案.pptx

    临时表(Temporary Table)在Oracle中用于存储临时数据,这些数据只在当前会话或者事务中有效。临时表空间则用来存储这些临时表,根据ON COMMIT选项,可以设置临时表在事务提交后是否自动清空。临时表的特点是它们的...

    MySQL与Oracle SQL语言差异比较一览

    - `VARCHAR2`在Oracle中用于存储可变长度的字符串,而在MySQL中对应的类型是`VARCHAR`。 - 日期类型在Oracle中为`DATE`,包括年月日时分秒信息,而在MySQL中,日期字段分为`DATE`和`TIME`,但也可以使用`DATETIME`...

    oracle恢复工具-FY_Recover_Data

    从红色字体可以看出,恢复72622条,刚好是truncate前业务表中记录数,恢复临时表为:SYS.TRUNTAB1$$2 第七步:查看输出内容和构造表名: insert into truntab1 select * from SYS.TRUNTAB1$$2 第八步:验证...

    oracle9i中文版基础培训教程7宣贯.pdf

    4. **数据表类型**:除了标准的关系表外,还有临时表,用于存储会话特定或私有的数据,不可被其他用户访问。 这些基本概念和数据类型是理解和操作Oracle 9i数据库的基础,通过熟练掌握它们,用户可以有效地设计、...

    sql的有关题目

    - 通过`VARIABLE no NUMBER`声明并初始化变量`no`,然后在匿名PL/SQL块中用`:no:=7369;`给变量赋值,最后在`Raise_Sal`过程中使用这个变量。 12. **Oracle的DBMS_OUTPUT包(DBMS_OUTPUT Package)** - `DBMS_...

    ADBMS3.8_plsql.pptx

    PL/SQL是Oracle数据库系统中的一个强大力量,它是一种结合了SQL查询语言和过程式编程的语言,用于在Oracle环境中创建复杂的应用程序。在“ADBMS3.8_plsql.pptx”中,主要讲解了Oracle下的PL/SQL基础知识,包括结构、...

    存储过程完整语句获取办法.docx

    `LONG`数据类型在Oracle中用于存储大段的文本数据,它可以容纳存储过程或函数的整个定义。 接下来,创建一个临时或中间表来存储这些语句。例如,你可以创建一个名为`WYF_TEST`的表,结构如下: ```sql CREATE ...

    第7章 游标和异常处理.ppt

    在某些情况下,需要把数据从存放在磁盘的表中调到计算机内存中进行处理,最后将处理结果显示出来或最终写回数据库。这样数据处理的速度才会提高,否则频繁的磁盘数据交换会降低效率。 Oracle游标有两种类型:隐式...

    Oracle 11GR2的递归WITH子查询方法

    Oracle 11GR2的递归WITH子查询是一种强大的功能,它允许你在SQL查询中创建递归关系,处理层级数据,比如组织结构、家族树或依赖关系等。WITH子查询,也称为公共表表达式(CTE),是SQL标准的一部分,自9i版本开始被...

    书籍《数据库面试笔试宝典》_辅助阅读pdf文档_2018080801

    - 多行子查询、合并查询、自然连接、自连接和WITH语句:这些是SQL中用于数据查询和操作的高级技术,涉及到多表查询和临时表的使用。 - SQL注入:SQL注入是一种安全漏洞,它允许攻击者通过将恶意的SQL代码插入到输入...

Global site tag (gtag.js) - Google Analytics