当前位置:  数据库>oracle

Oracle中创建和删除临时表

    来源: 互联网  发布时间:2017-06-09

    本文导语: CREATE GLOBAL TEMPORARY TABLE TABLENAME (    COL1  VARCHAR2(10),    COL2  NUMBER ) ON COMMIT PRESERVE(DELETE) ROWS ; --ON COMMIT DELETE ROWS 说明临时表是事务指定,每次提交后Oracle将截断表(删除全部行)---------------------------------------在Oracle8i中,可以创...

CREATE GLOBAL TEMPORARY TABLE TABLENAME (
    COL1  VARCHAR2(10),
    COL2  NUMBER
 ) ON COMMIT PRESERVE(DELETE) ROWS ;

--ON COMMIT DELETE ROWS 说明临时表是事务指定,每次提交后Oracle将截断表(删除全部行)
---------------------------------------
在Oracle8i中,可以创建以下两种临时表:
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将截断表。


procedure 执行一系列的操作
package  可以在其中定义一些量、函数、过程等;

 存储过程里不能直接使用DDL语句,所以只能使用动态SQL语句来执行

create procedure pro
 as
 str varchar2(100);
 begin

str := 'CREATE GLOBAL TEMPORARY TABLE admin_work_area
        (startdate DATE,
          enddate DATE,
          class CHAR(20))
      ON COMMIT DELETE ROWS’;
execute immediate str;
 end;


删除:

truncate table  MyTempTable
 drop table  MyTempTable

ORA-22992: 无法使用从远程表选择的 LOB 定位器 

解决办法:
可以先创建一个临时表,然后把远程有LOB字段的表克隆到临时表中,然后再进行链接操作
1.本地创建临时表
Sql代码
 
create global temporary table photo_temp as select * from photo@photo_link where 1=2 ;

2.用database link导入远程数据到临时表
Sql代码
 
insert into photo_temp select * from photo@photo_link;--不要commit;否则临时表中数据消失

3.把临时表数据插入到永久表中:
Sql代码
insert into photo select * from photo_temp;
commit;

实例:

create global temporary table pic_temp as select * from WH_REGISTERPIC@ogdpshdb where 1=2 ;
insert into pic_temp select * from WH_REGISTERPIC@ogdpshdb;
insert into WH_REGISTERPIC select * from pic_temp;
commit;

删除临时表:

truncate table  pic_temp ;
drop table  pic_temp ;

解决普通用户在存储过程中无权建临时表问题:

在包头中加 AUTHID CURRENT_USER

例子:

create or replace package WH_Info_Output AUTHID CURRENT_USER is

  -- Author  : 
  -- Created : 2014年9月2日 15:27:25
  -- Purpose : 

  --删除原有数据导入全部数据
  procedure SP_WH_Info_Output_All(Fid in number default 1);
  -- Public type declarations
  --传入参数默认0:导入没有的数据  1:删除原有数据导入全部数据
  procedure SP_WH_Info_Output(Fid in number default 0);

  --导入WH_REGISTERPIC表(含有BLOG字段) 0:导入没有的数据  1:删除原有数据导入全部数据
  procedure SP_WH_PIC_BLOGInfo_Output(Fid in number default 0);
 
end WH_Info_Output;

 

  --导入WH_REGISTERPIC表(含有BLOG字段) 0:导入没有的数据  1:删除原有数据导入全部数据
  procedure SP_WH_PIC_BLOGInfo_Output(Fid in number default 0)
  is
  str varchar2(300);
  begin
  if Fid = 0 then
  str:='create global temporary table pic_temp as select * from WH_REGISTERPIC@ogdpshdb where 1=2'; 
  execute immediate str; 
  str:='insert into pic_temp select * from WH_REGISTERPIC@ogdpshdb w where (w.WELLID, w.PICTYPECODE, w.VERSIONNO, w.PICFILENAME) not in (select WELLID, PICTYPECODE, VERSIONNO, PICFILENAME from WH_REGISTERPIC)'; 
  execute immediate str;    ----使用动态SQL语句来执行 
  str:='insert into WH_REGISTERPIC select * from pic_temp'; 
      execute immediate str; 
  end if;
 

  end SP_WH_PIC_BLOGInfo_Output;

在CentOS 6.4下安装Oracle 11gR2(x64)

Oracle 11gR2 在VMWare虚拟机中安装步骤

Debian 下 安装 Oracle 11g XE R2


    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • 请教:为什么删除不掉?我用超级用户删除某一文件夹rm -R oracle失败。
  • 在linux 中如何删除oracle db 与卸载oracle.
  • Oracle删除表前判断表名是否存在若存在则删除
  • oracle创建删除用户示例分享(oracle删除用户命令及授权)
  • oracle 彻底删除方法
  • Oracle删除后不能重新安装的解决方法
  • ubuntu如何彻底删除oracle
  • 彻底删除Oracle数据库的方法
  • Oracle删除当前用户下所有表的方法适用于有或没有删除权限
  • Web服务器/前端 iis7站长之家
  • 技巧分享 删除Oracle10G中的垃圾表
  • Oracle删除带有空格的表
  • 请问怎么用jsp语句删除oracle中的一条记录?
  • Linux环境下完全删除Oracle
  • oracle怎么删除用户提供解决方案
  • linux下如何卸载oracle?直接删除就可以么??
  • oracle单库彻底删除干净的执行步骤
  • 删除Oracle中奇怪的表名称BIN$…的方法
  • linux oracle数据库删除操作指南
  • oracle数据库添加或删除一列的sql语句
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle 10g和Oracle 11g网格技术介绍


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,