快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

在ORACLE 数据库中的临时表用法汇总

 说明:下文中的一些说明和示例代码摘自CSDN,恕不一一指明出处,在此一并对相关作者表示感谢!

  1 语法

  在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将截断表。  

  2 动态创建

  create or replace procedure pro_temp(v_col1 varchar2,v_col2 varchar2) as

  v_num number;

  begin

  select count(*) into v_num from user_tables where table_name=\\\'T_TEMP\\\';  

  --create temporary table

  if v_num<1 then

  execute immediate \\\'CREATE GLOBAL TEMPORARY TABLE T_TEMP (

  COL1 VARCHAR2(10),

  COL2 VARCHAR2(10)

  ) ON COMMIT delete ROWS\\\';

  end if;  

  --insert data

  execute immediate \\\'insert into t_temp values(\\\'\\\'\\\'  v_col1  \\\'\\\'\\\',\\\'\\\'\\\'  v_col2  \\\'\\\'\\\')\\\';  

  execute immediate \\\'select col1 from t_temp\\\' into v_num;

  dbms_output.put_line(v_num);

  execute immediate \\\'delete from t_temp\\\';

  commit;

  execute immediate \\\'drop table t_temp\\\';

  end pro_temp;  

  测试:  

  15:23:54 SQL> set serveroutput on

  15:24:01 SQL> exec pro_temp(\\\'11\\\',\\\'22\\\');

  11  

  PL/SQL 过程已成功完成。  

  已用时间: 00: 00: 00.79

  15:24:08 SQL> desc t_temp;

  ERROR:

  ORA-04043: 对象 t_temp 不存在  

  3 特性和性能(与普通表和视图的比较)

   临时表只在当前连接内有效

  临时表不建立索引,所以假如数据量比较大或进行多次查询时,不推荐使用

  数据处理比较复杂的时候时表快,反之视图快点

  在仅仅查询数据的时候建议用游标: open cursor for \\\'sql clause\\\';
返回类别: 教程
上一教程: 在SQL中删除重复记录(多种方式)
下一教程: MYSQL5.0触发器

您可以阅读与"在ORACLE 数据库中的临时表用法汇总"相关的教程:
· 使用MD5加密数据库中的用户密码
· 将EXCEL中的数据导入到SQL SERVER 2000数据库中
· 将Excel中的数据导入到SQL Server 2000数据库中
· 使用MD5加密数据库中的用户密码(二)
· 如何删除数据库中的冗余数据
    微笑服务 优质保证 索取样品