`

Orcale创建临时表

阅读更多

在Oracle8i或以上版本中,可以创建以下两种临时表:    
  1。会话特有的临时表    
          CREATE   GLOBAL   TEMPORARY   <TABLE_NAME>   (<column   specification>)    
          ON   COMMIT   PRESERVE   ROWS;    
       
  2。事务特有的临时表    
          CREATE   GLOBAL   TEMPORARY   <TABLE_NAME>   (<column   specification>)    
          ON   COMMIT   DELETE   ROWS;    
        CREATE   GLOBAL   TEMPORARY   TABLE   MyTempTable    
  所建的临时表虽然是存在的,但是你试一下insert   一条记录然后用别的连接登上去select,记录是空的,明白了吧,我把下面两句话再贴一下:    
  --ON   COMMIT   DELETE   ROWS   说明临时表是事务指定,每次提交后ORACLE将截断表(删除全部行)    
  --ON   COMMIT   PRESERVE   ROWS   说明临时表是会话指定,当中断会话时ORACLE将截断表。    
  冲突的问题更本不用考虑.    
       
  临时表只是保存当前会话(session)用到的数据,数据只在事务或会话期间存在。    
       
  通过CREATE   GLOBAL   TEMPORARY   TABLE命令创建一个临时表,对于事务类型的临时表,    
  数据只是在事务期间存在,对于会话类型的临时表,数据在会话期间存在。    
       
  会话的数据对于当前会话私有。每个会话只能看到并修改自己的数据。DML锁不会加到    
  临时表的数据上。下面的语句控制行的存在性。    
         
  ●   ON   COMMIT   DELETE   ROWS   表名行只是在事务期间可见    
  ●   ON   COMMIT   PRESERVE   ROWS   表名行在整个会话期间可见    
       
  可以对临时表创建索引,视图,出发器,可以用export和import工具导入导出表的    
  定义,但是不能导出数据。表的定义对所有的会话可见。  

 

Temporary   Tables临时表  
  1简介  
        ORACLE数据库除了可以保存永久表外,还可以建立临时表temporary   tables。这些临时表用来保存一个会话SESSION的数据,  
        或者保存在一个事务中需要的数据。当会话退出或者用户提交commit和回滚rollback事务的时候,临时表的数据自动清空,  
        但是临时表的结构以及元数据还存储在用户的数据字典中。  
        临时表只在oracle8i以及以上产品中支持。  
  2详细介绍  
        Oracle临时表分为   会话级临时表   和   事务级临时表。  
  会话级临时表是指临时表中的数据只在会话生命周期之中存在,当用户退出会话结束的时候,Oracle自动清除临时表中数据。  
  事务级临时表是指临时表中的数据只在事务生命周期中存在。当一个事务结束(commit   or   rollback),Oracle自动清除临时表中数据。  
  临时表中的数据只对当前Session有效,每个Session都有自己的临时数据,并且不能访问其它Session的临时表中的数据。因此,  
  临时表不需要DML锁.当一个会话结束(用户正常退出   用户不正常退出   ORACLE实例崩溃)或者一个事务结束的时候,Oracle对这个会话的  
  表执行   TRUNCATE   语句清空临时表数据.但不会清空其它会话临时表中的数据.  
  你可以索引临时表和在临时表基础上建立视图.同样,建立在临时表上的索引也是临时的,也是只对当前会话或者事务有效.      
  临时表可以拥有触发器.  
  3建立临时表  
        临时表的定义对所有会话SESSION都是可见的,但是表中的数据只对当前的会话或者事务有效.    
        建立方法:  
  1)   ON   COMMIT   DELETE   ROWS   定义了建立事务级临时表的方法.  
  CREATE   GLOBAL   TEMPORARY   TABLE   admin_work_area  
                  (startdate   DATE,  
                    enddate   DATE,  
                    class   CHAR(20))  
              ON   COMMIT   DELETE   ROWS;  
  EXAMPLE:  
  SQL>   CREATE   GLOBAL   TEMPORARY   TABLE   admin_work_area  
      2                     (startdate   DATE,  
      3                       enddate   DATE,  
      4                       class   CHAR(20))  
      5                 ON   COMMIT   DELETE   ROWS;  
  SQL>   create   table   permernate(   a   number);  
  SQL>   insert   into   admin_work_area   values(sysdate,sysdate,'temperary   table');  
  SQL>   insert   into   permernate   values(1);  
  SQL>   commit;  
  SQL>   select   *   from   admin_work_area;  
  SQL>   select     *   from   permernate;  
  A  
  1  

备注 :在commit执行之前是可以查询到临时表的数据的;
  2)ON   COMMIT   PRESERVE   ROWS   定义了创建会话级临时表的方法.  
  CREATE   GLOBAL   TEMPORARY   TABLE   admin_work_area  
                  (startdate   DATE,  
                    enddate   DATE,  
                    class   CHAR(20))  
            ON   COMMIT   PRESERVE   ROWS;  
  EXAMPLE:  
   
  会话1:  
  SQL>   drop   table   admin_work_area;  
  SQL>   CREATE   GLOBAL   TEMPORARY   TABLE   admin_work_area  
      2                     (startdate   DATE,  
      3                       enddate   DATE,  
      4                       class   CHAR(20))  
      5               ON   COMMIT   PRESERVE   ROWS;  
  SQL>   insert   into   permernate   values(2);  
  SQL>   insert   into   admin_work_area   values(sysdate,sysdate,'session   temperary');  
  SQL>   commit;  
  SQL>   select   *   from   permernate;  
   
                    A  
  ----------  
                    1  
                    2  
   
  SQL>   select   *   from   admin_work_area;  
   
  STARTDATE     ENDDATE         CLASS  
  ----------   ----------   --------------------  
  17-1??   -03   17-1??   -03   session   temperary  

备注:当前会话不能执行:drop   table   admin_work_area;  
    
  会话2:   (打开另外的窗口)
   
  SQL>   select   *   from   permernate;  
   
                    A  
  ----------  
                    1  
                    2  
   
  SQL>   select   *   from   admin_work_area;  
   
  未选择行.  
   
  会话2看不见会话1中临时表的数据.  

附加

create global temporary table test_temp
on commit delete rows as
(select * from portal_entity_title where 1=2);

这条语句可以将portal_entity_title表中的字段全部赋给临时表test_temp.

分享到:
评论

相关推荐

    Oracle 临时表用法

    本文将详细介绍Oracle临时表的创建方法、使用场景以及优缺点,帮助读者更好地理解和运用这一特性。 #### 二、Oracle临时表概述 Oracle临时表是一种特殊的表,用于存储临时数据,通常用于事务处理或特定会话期间的...

    oracle创建临时表空间文档及工具

    本文档将深入探讨如何在Oracle中创建临时表空间,并介绍一款方便的一键导入、导出工具。 首先,我们来看如何创建临时表空间。在Oracle中,创建临时表空间的SQL语句通常如下: ```sql CREATE TEMPORARY TABLESPACE ...

    oracle临时表用法

    Oracle 临时表用法 Oracle 临时表是一种特殊的表结构,它可以在数据库中临时存储...但是,使用临时表时需要注意一些问题,例如避免在存储过程中创建临时表,避免在运行时创建临时表,以免导致数据库中的表数量增加。

    学习oracle创建一个表空间创建临时表空间创建用户表空间资源的权限

    创建临时表空间的步骤与创建常规表空间相似,只是需要指定`TEMPORARY TABLESPACE`: ```sql CREATE TEMPORARY TABLESPACE MY_TEMP TEMPFILE '/u01/app/oracle/oradata/MY_DB/MY_TEMP.dbf' SIZE 20M AUTOEXTEND...

    ORACLE中临时表

    需要注意的是,与SQL Server和Sybase等其他数据库系统相比,Oracle中不应在运行时动态创建临时表,而应在应用程序安装时创建。DDL操作(如创建表)开销较大,应尽量避免在运行时执行。 总结来说,Oracle的临时表...

    Oracle临时表空间满的解决步骤

    解决 Oracle 临时表空间满的问题需要通过查看当前数据库的默认临时表空间、查看当前临时表空间的大小、创建新的临时表空间、将新建的临时表空间设置为数据库的默认临时表空间、删除原来的临时表空间、创建新的临时表...

    Oracle 临时表之临时表的应用问题

    网上有人给出了佳的优化思路是: ...  with子查询实际上也是用了临时表,Oracle会替你创建一张临时表,因此临时表的开销WITH子查询也会有。只要把AUTOTRACE打开你会看到REDO的开销。  关于临时表的使用至

    Oracle中临时表的创建

    本文将详细介绍如何在Oracle中创建临时表,并探讨其应用场景以及两种主要类型的临时表:全局临时表(Global Temporary Table)与局部临时表(Local Temporary Table)的区别及其使用方法。 #### 二、Oracle临时表...

    Oracle存储过程中使用临时表

    1. **创建临时表**:使用`CREATE GLOBAL TEMPORARY TABLE`语句创建临时表。例如: ```sql CREATE GLOBAL TEMPORARY TABLE temp_table ( column1 datatype, column2 datatype, ... ) ON COMMIT DELETE ROWS; `...

    Oracle释放临时表空间脚本

    ### Oracle 临时表空间管理与释放脚本解析 在Oracle数据库管理中,临时表空间(Temporary Tablespace)的管理是一项非常重要的任务。合理的管理和优化临时表空间不仅可以提高系统的性能,还可以帮助解决空间不足等...

    Oracle创建表空间、临时表、用户及用户授权

    在Oracle数据库管理中,表空间...以上就是Oracle数据库中创建表空间、临时表、用户及用户授权的基本步骤。在实际操作中,DBA应根据业务需求和安全性考虑来合理规划和管理这些元素,确保数据库的稳定运行和数据的安全。

    oracle-临时表空间

    创建临时表空间 创建一个新的临时表空间,可以使用以下命令: ```sql CREATE TEMPORARY TABLESPACE ygj_temp TEMPFILE '/opt/oracle10g/oradata/orcl/ygj_temp.dbf' SIZE 32M AUTOEXTEND ON NEXT 32M MAXSIZE ...

    oracle11g创建临时表空间组

    ### Oracle 11g 创建临时表空间组 在Oracle 11g R2版本中,引入了临时表空间组的概念,这一特性为数据库管理提供了更大的灵活性。与传统的单个临时表空间相比,临时表空间组允许多个临时表空间协同工作,从而提高...

    oracle创建表空间用户等

    ### Oracle 创建表空间、用户及分配权限详解 在Oracle数据库管理中,创建表空间和用户是常见的基础操作之一。本文将详细介绍如何在Oracle数据库中创建表空间、创建用户并分配相应的权限,以及如何设置表空间的自...

    oracle临时表(事务级、会话级).docx

    全局临时表以数学符号 (##) 打头,创建后对任何用户都是可见的。当所有引用该表的用户从 SQL Server 断开连接时,被删除。 Oracle 临时表和 SQL Server 临时表都是用来保存临时数据的表,但它们有不同的特点和用途...

    Oracle 19c创建表空间及用户.txt

    Oracle 19c创建表空间及用户

    oracle 创建表空间命令

    此外,还可以为用户指定临时表空间,用于处理临时数据,如排序和并行查询: ```sql ALTER USER myuser TEMPORARY TABLESPACE temp_tablespace; ``` 这里的`temp_tablespace`应替换为实际的临时表空间名。 总结起来...

    Oracle 临时表空间使用注意

    当用户进行如大型查询、创建索引或执行联接查询等涉及排序操作时,系统会自动在临时表空间中分配内存来存储中间结果。这是因为这些操作通常需要比内存更大的空间,而临时表空间提供了一个磁盘上的空间来处理这种情况...

    oracle临时表操作学习资料

    默认情况下,如果没有明确指定,Oracle将创建的临时表视为事务临时表。为清晰起见,建议使用`ON COMMIT DELETE ROWS`关键字来标识事务临时表。 - **数据变化**:在事务临时表中插入的数据仅在当前事务内有效。事务...

    Oracle特性临时表

    - 使用`CREATE GLOBAL TEMPORARY TABLE`语句创建临时表。 - 可以通过`ON COMMIT`子句来定义数据的生命周期,即数据在何时被清除。 #### 三、创建临时表 **1. 基本语法:** ```sql CREATE GLOBAL TEMPORARY TABLE ...

Global site tag (gtag.js) - Google Analytics