如何创建临时表,

解决方案 »

  1.   

    CREATE  GLOBAL  TEMPORARY  TABLE  flight_schedule  (  
         startdate  DATE,    
         enddate  DATE,    
         cost  NUMBER)  
      

  2.   


    /*
    首先是创建临时表的语法: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 表,临时表还是在数据字典中存在的。*/
      

  3.   

      gbstr:='create GLOBAL TEMPORARY table gb_temp(mrn Integer,itemname varchar2(200),ts Integer) ON COMMIT PRESERVE ROWS';   execute immediate gbstr;
       insert into gb_temp 
       select max(rn),strValue10,count(1) from Procedure_Tmp group by strValue10;
    这里哪里错了
      

  4.   

    --全动态  gbstr:='create GLOBAL TEMPORARY table gb_temp(mrn Integer,itemname varchar2(200),ts Integer) ON COMMIT PRESERVE ROWS';  execute immediate gbstr;
      execute immediate 'insert into gb_temp  
      select max(rn),strValue10,count(1) from Procedure_Tmp group by strValue10';