CREATE TABLE #TMP(FIELD1 INT,FIELD2 VARCHAR(30))
或
CREATE TABLE ##TMP(FIELD1 INT,FIELD2 VARCHAR(30))
临时表应该也有特殊的标识,创建的语言应该是一样的,
只不过是标识不一样而已,可以查一下orcle中临时表的标识,
然后再试下,
呵呵,希望能有帮助,^_^
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';
临时表的创建
创建oracle临时表,可以有两种类型的临时表:会话级的临时表和事务级的临时表。
1)会话级的临时表因为这这个临时表中的数据和你的当前会话有关系,当你当前session不退出的情况下,临时表中的数据就还存在,而当你退出当前session的时候,临时表中的数据就全部没有了,当然这个时候你如果以另外一个session登陆的时候是看不到另外一个session中插入到临时表中的数据的。即两个不同的session所插入的数据是互不相干的。当某一个session退出之后临时表中的数据就被截断(truncate table,即数据清空)了。会话级的临时表创建方法:create global temporary table table_name(col1 type1,col2 type2...) on commit preserve rows;举例create global temporary table student(stu_id number(5),class_id number(5),stu_name varchar2(8),stu_memo varchar2(200)) on commit preserve rows ;
2)事务级临时表是指该临时表与事务相关,当进行事务提交或者事务回滚的时候,临时表中的数据将自行被截断,其他的内容和会话级的临时表的一致(包括退出session的时候,事务级的临时表也会被自动截断)。事务级临时表的创建方法:create global temporary table table_name(col1 type1,col2 type2...) on commit delete rows;举例:create global temporary table classes(class_id number(5),class_name varchar2(8),class_memo varchar2(200)) on commit delete rows ;
3)、两种不通类型的临时表的区别:语法上,会话级临时表采用on commit preserve rows而事务级则采用on commit delete rows;用法上,会话级别只有当会话结束临时表中的数据才会被截断,而且事务级临时表则不管是commit、rollback或者是会话结束,临时表中的数据都将被截断。
例子:
1)、会话级(session关闭掉之后数据就没有了,当commit的时候则数据还在,当rollback的时候则数据也是一样被回滚):
insert into student(stu_id,class_id,stu_name,stu_memo) values(1,1,'张三','福建');
insert into student(stu_id,class_id,stu_name,stu_memo) values(2,1,'刘德华','福州');
insert into student(stu_id,class_id,stu_name,stu_memo) values(3,2,'s.h.e','厦门');
sql> select *from student ;
stu_id class_id stu_name stu_memo
------ -------- -------- --------------------------------------------------------------------------------
1 1 张三 福建
2 1 刘德华 福州
3 2 s.h.e 厦门
4 2 张惠妹 厦门
sql> commit;
commit complete
sql> select * from student ;
stu_id class_id stu_name stu_memo
------ -------- -------- --------------------------------------------------------------------------------
1 1 张三 福建
2 1 刘德华 福州
3 2 s.h.e 厦门
4 2 张惠妹 厦门
sql>insert into student(stu_id,class_id,stu_name,stu_memo) values(4,2,'张惠妹','厦门');
1 row inserted
sql> select * from student ;
stu_id class_id stu_name stu_memo
------ -------- -------- --------------------------------------------------------------------------------
1 1 张三 福建
2 1 刘德华 福州
3 2 s.h.e 厦门
4 2 张惠妹 厦门
4 2 张惠妹 厦门
sql> rollback ;
rollback complete
sql> select * from student ;
stu_id class_id stu_name stu_memo
------ -------- -------- --------------------------------------------------------------------------------
1 1 张三 福建
2 1 刘德华 福州
3 2 s.h.e 厦门
4 2 张惠妹 厦门
sql>
2)、事务级(commit之后就删除数据):本例子将采用以下的数据:
insert into classes(class_id,class_name,class_memo) values(1,'计算机','9608');
insert into classes(class_id,class_name,class_memo) values(2,'经济信息','9602');
insert into classes(class_id,class_name,class_memo) values(3,'经济信息','9603');
在一个session中(比如sqlplus登陆)插入上面3条记录,然后再以另外一个session(用sqlplus再登陆一次)登陆,当你select * from classes;的时候,classes表是空的,而你再第一次登陆的sqlplus中select的时候可以查询到,这个时候你没有进行commit或者rollback之前你可以对刚才插入的3条记录进行update、delete等操作,当你进行commit或者rollback的时候,这个时候由于你的表是事务级的临时表,那么在插入数据的session也看不到数据了,这个时候数据就已经被截断了。
运行结果如下:
sql> insert into classes(class_id,class_name,class_memo) values(1,'计算机','9608');
1 row inserted
sql> insert into classes(class_id,class_name,class_memo) values(2,'经济信息','9602');
1 row inserted
sql> insert into classes(class_id,class_name,class_memo) values(3,'经济信息','9603');
1 row inserted
sql> update classes set class_memo ='' where class_id=3 ;
1 row updated
sql> select * from classes ;
class_id class_name class_memo
-------- ---------- --------------------------------------------------------------------------------
1 计算机 9608
2 经济信息 9602
3 经济信息
sql> delete from classes where class_id=3 ;
1 row deleted
sql> select * from classes ;
class_id class_name class_memo
-------- ---------- --------------------------------------------------------------------------------
1 计算机 9608
2 经济信息 9602
sql> commit;
commit complete
sql> select *from classes ;
class_id class_name class_memo
-------- ---------- --------------------------------------------------------------------------------
sql>
再重复插入一次,然后rollback。
sql> rollback ;
rollback complete
sql> select * from classes ;
class_id class_name class_memo
-------- ---------- --------------------------------------------------------------------------------
sql>
临时表的应用
1)、当某一个sql语句关联的表在2张及以上,并且和一些小表关联。可以采用将大表进行分拆并且得到比较小的结果集合存放在临时表中。
2)、程序执行过程中可能需要存放一些临时的数据,这些数据在整个程序的会话过程中都需要用的等等。
5、注意事项:
1)、临时表的索引以及对表的修改、删除等和正常的表是一致的。
2)、oracle的临时表是oracle8i才支持的功能特性,如果你的oracle版本比较低的话,那么就可能没有办法用到了,如果你的oracle版本是8i的话,你还需要把$oracle_home/admin/${oracle_sid}/pfile目录下的init