热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

如何在oracle存储过程中建立临时表

createprocedure**()isbeginselect);createtable××(avarch
create procedure **
(....
.....)
is 
begin
select ......
......);

create table ××
(a varchar2 not null,
   ........);

end **
这种方式可以吗?在建立表的时候,如a这样字段是不是在开始的时候定义?

5 个解决方案

#1


过程、函数里面不能直接使用ddl语句,可以借助动态sql来实现,如:
execute immediate 'create table xx (a varchar2(10),b int)';
不需要事先定义字段名、表名,当然也可用变量来存储表名或整个建表语句.

#2


这种方式可以吗?在建立表的时候,如a这样字段是不是在开始的时候定义?

在过程、函数里面不能直接使用ddl语句,需要动态的来创建
str  varchar(2000);
begin
str :='create table'||table_name||'(a varchar2 not null,   ........)';
-----动态构造CREATE语句
execute immediate str;---执行SQL语句

#3


可以给你一个例子
//用存储过程来创建表,如果该表存在就删除他,然后创建新表

create or replace procedure create_user_login --没有参数,这里不要括弧
IS
  i INTEGER;
BEGIN

 SELECT COUNT(*) INTO i FROM user_tables where table_name=Upper('user_login') ;
 
if i > 0 then
   EXECUTE IMMEDIATE 'drop table user_login';
end if;
EXECUTE immediate 'create table user_login
(id        integer primary key,
 name      varchar2(20),
 sex       varchar2(4),
 office_id integer,
 bussiness varchar2(100),
 tele      varchar2(20),
 pirror_id integer,
 photo     long raw,
 password  varchar2(20),
 regist_date date,
 invalid_date date)';
END;
-- EXISTS 只能用在SQL语句中
-- tablename需转换成大写,否则查询不到
-- 用EXECUTE IMMEDIATE语句须用户有EXECUTE权限

#4


oracle里面的零时表和sybase的不一样,
sybase里的零时表不同session看不见各自的表
而oracle里面的零时表是不同session不能互见表数据,但是表是可以互见的

所以我建议你,零时表还是在外面建立,存储过程里不要建零时表,不然一个:表存在会报错,还有一个:会导致存储过程效率很低

#5


create procedure pro
as
str varchar2(100);
begin
str:='CREATE GLOBAL TEMPORARY TABLE TABLENAME (
   COL1  VARCHAR2(10),
   COL2  NUMBER
) ON COMMIT PRESERVE ROWS';
execute immediate str;
end;
/

推荐阅读
author-avatar
心醉逸轩_620
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有