oracle创建临时表

合集下载

oracle创建临时表的方法

oracle创建临时表的方法

Oracle数据库是一种被广泛应用的关系型数据库管理系统,它提供了许多强大的功能来满足不同的数据库需求。

其中,创建临时表是在数据库开发和管理中经常会用到的功能之一。

本文将为大家介绍在Oracle数据库中创建临时表的方法,并提供一些注意事项和最佳实践。

一、什么是临时表在Oracle数据库中,临时表是一种特殊的表,它的数据仅在当前会话或事务中存在,并在会话或事务结束后自动删除。

临时表通常用于存储临时数据,或者在复杂的数据处理过程中起到缓冲的作用。

在Oracle中,临时表可以通过全局临时表和局部临时表两种方式来实现。

1. 全局临时表全局临时表是一种在数据库中存在的临时表,它对所有会话都可见,但表中的数据仅对创建它的会话可见。

全局临时表的数据在会话结束时自动删除,但表的结构保持不变,其他会话可以重复使用该表。

在Oracle中,创建全局临时表需要使用CREATE GLOBAL TEMPORARY TABLE语句,并在表名后添加ON COMMIT DELETE ROWS选项来指定表的删除规则。

2. 局部临时表局部临时表是一种在会话中存在的临时表,它对当前会话可见,但对其他会话不可见。

局部临时表的数据在当前会话结束时自动删除,表的结构也随之消失。

在Oracle中,创建局部临时表需要使用CREATETEMPORARY TABLE语句,并在表名后添加ON COMMIT DELETE ROWS选项来指定表的删除规则。

二、创建全局临时表的方法在Oracle数据库中,创建全局临时表可以通过以下步骤来完成:1. 使用CREATE GLOBAL TEMPORARY TABLE语句定义临时表的结构,例如:```sqlCREATE GLOBAL TEMPORARY TABLE temp_table(id NUMBER,name VARCHAR2(50))ON COMMIT DELETE ROWS;```2. 在创建表的也可以定义表的索引和约束等其他特性,以满足具体的需求。

oracle临时表的用法总结

oracle临时表的用法总结

oracle临时表的用法总结oracle临时表的用法总结1、前言目前所有使用Oracle作为数据库支撑平台的应用,大部分数据量比较庞大的系统,即表的数据量一般情况下都是在百万级以上的数据量。

当然在Oracle中创建分区是一种不错的选择,但是当你发现你的应用有多张表关联的时候,并且这些表大部分都是比较庞大,而你关联的时候发现其中的某一张或者某几张表关联之后得到的结果集非常小并且查询得到这个结果集的速度非常快,那么这个时候我考虑在Oracle中创建“临时表”。

我对临时表的理解:在Oracle中创建一张表,这个表不用于其他的什么功能,主要用于自己的软件系统一些特有功能才用的,而当你用完之后表中的数据就没用了。

Oracle的临时表创建之后基本不占用表空间,如果你没有指定临时表(包括临时表的索引)存放的表空的时候,你插入到临时表的数据是存放在ORACLE系统的临时表空间中(TEMP)。

2、临时表的创建创建Oracle临时表,可以有两种类型的临时表:会话级的临时表事务级的临时表。

1)会话级的临时表因为这这个临时表中的数据和你的当前会话有关系,当你当前不退出的情况下,临时表中的数据就还存在,而当你退出当前的时候,临时表中的数据就全部没有了,当然这个时候你如果以另外一个登陆的时候是看不到另外一个中插入到临时表中的数据的。

即两个不同的所插入的数据是互不相干的。

当某一个退出之后临时表中的数据就被截断(truncatetable,即数据清空)了。

会话级的临时表创建方法:CreateGlobalTemporaryTableTable_Name(Col1Type1,Col2Type2...)OnCommitPreserveRows;举例:createglobaltemporarytableStudent(Stu_idNumber(5),Class_idNumber(5),Stu_NameVarchar2(8),Stu_Memovarchar2(200))onCommitPreserveRows;2)事务级临时表是指该临时表与事务相关,当进行事务提交或者事务回滚的时候,临时表中的数据将自行被截断,其他的内容和会话级的临时表的一致(包括退出的时候,事务级的临时表也会被自动截断)。

oracle创建临时表空间、用户表空间语句

oracle创建临时表空间、用户表空间语句

创建临时表‎空间C‎R EATE‎TEMP‎O RARY‎TABL‎E SPAC‎E tes‎t_tem‎pTEM‎P FILE‎'D:\‎M yOrc‎l\orc‎l\tes‎t_tem‎p01.d‎b f'S‎I ZE 3‎2MAU‎T OEXT‎E ND O‎NNEX‎T 32M‎MAXS‎I ZE 2‎048M‎E XTEN‎T MAN‎A GEME‎N T LO‎C AL;‎创建‎用户表空间‎CRE‎A TE T‎A BLES‎P ACE ‎t est_‎d ata‎L OGGI‎N GDA‎T AFIL‎E 'D:‎\MyOr‎c l\or‎c l\TE‎S T_DA‎T A01.‎D BF' ‎SIZE‎32M ‎AUTO‎E XTEN‎D ON ‎NEXT‎32M ‎M AXSI‎Z E 20‎48ME‎X TENT‎MANA‎G EMEN‎T LOC‎A L;‎创建‎用户并制定‎表空间‎C REAT‎E USE‎R wjz‎IDEN‎T IFIE‎D BY ‎t iger‎DEFA‎U LT T‎A BLES‎P ACE ‎T EST_‎D ATA‎T EMPO‎R ARY ‎T ABLE‎S PACE‎TEST‎_TEMP‎;‎给用‎户授予权限‎GRA‎N T‎CREA‎T E SE‎S SION‎, CRE‎A TE A‎N Y TA‎B LE, ‎C REAT‎E ANY‎VIEW‎,CRE‎A TE A‎N Y IN‎D EX, ‎C REAT‎E ANY‎PROC‎E DURE‎,A‎L TER ‎A NY T‎A BLE,‎ALTE‎R ANY‎PROC‎E DURE‎,D‎R OP A‎N Y TA‎B LE, ‎D ROP ‎A NY V‎I EW, ‎D ROP ‎A NY I‎N DEX,‎DROP‎ANY ‎P ROCE‎D URE,‎SE‎L ECT ‎A NY T‎A BLE,‎INSE‎R T AN‎Y TAB‎L E, U‎P DATE‎ANY ‎T ABLE‎,DEL‎E TE A‎N Y TA‎B LE‎TO w‎j z;‎将r‎o le这个‎角色授与u‎s erna‎m e,也就‎是说,使u‎s erna‎m e这个用‎户可以管理‎和使用ro‎l e所拥有‎的资源,前‎提是数据库‎内有rol‎e这个角色‎GRA‎N T ro‎l e TO‎user‎n ame;‎‎查看所有用‎户SEL‎E CT *‎FROM‎DBA_‎U SERS‎;SEL‎E CT *‎FROM‎ALL_‎U SERS‎;SEL‎E CT *‎FROM‎USER‎_USER‎S;‎查看用户系‎统权限S‎E LECT‎* FR‎O M DB‎A_SYS‎_PRIV‎S;SE‎L ECT ‎* FRO‎M USE‎R_SYS‎_PRIV‎S;‎查看用户对‎象权限S‎E LECT‎* FR‎O M DB‎A_TAB‎_PRIV‎S;SE‎L ECT ‎* FRO‎M ALL‎_TAB_‎P RIVS‎;SEL‎E CT *‎FROM‎USER‎_TAB_‎P RIVS‎;查‎看所有用户‎SELE‎C T * ‎F ROM ‎D BA_R‎O LES;‎查看‎用户或角色‎所拥有的角‎色SEL‎E CT *‎FROM‎DBA_‎R OLE_‎P RIVS‎;SEL‎E CT *‎FROM‎USER‎_ROLE‎_PRIV‎S;‎。

[转]关于oraclewithtableas创建临时表的用法示例

[转]关于oraclewithtableas创建临时表的用法示例

[转]关于oraclewithtableas创建临时表的用法示例1、with table as 相当于建个临时表(用于一个语句中某些中间结果放在临时表空间的SQL语句),Oracle 9i 新增WITH语法,可以将查询中的子查询命名,放到SELECT语句的最前面。

语法就是with tempname as (select ....)select ...例子:with t as (select * from emp where depno=10)select * from t where empno=xxxwithwd as (select did,arg(salary) 平均工资from work group by did),em as (select emp.*,w.salary from emp left join work w on emp.eid = w.eid)select * from wd,em where wd.did =em.did and wd.平均工资>em.salary;2、何时被清除临时表不都是会话结束就自动被PGA清除嘛! 但with as临时表是查询完成后就被清除了!23:48:58 SCOTT@orcl> with aa as(select * from dept)23:57:58 2 select * from aa;DEPTNO DNAME LOC---------- -------------- -------------10 ACCOUNTING NEW YORK20 RESEARCH DALLAS30 SALES CHICAGO40 OPERATIONS BOSTON已用时间: 00: 00: 00.1223:58:06 SCOTT@orcl> select * from aa;select * from aa*第 1 行出现错误:ORA-00942: 表或视图不存在已用时间: 00: 00: 00.0223:58:14 SCOTT@orcl>3、就这一功能来说,子查询就可以达到啊,为什么要用with呢?用with有什么好处?都能写,但执行计划不同的。

在ORACLE存储过程中创建临时表

在ORACLE存储过程中创建临时表

在ORACLE存储过程中创建临时表在ORACLE存储过程中创建临时表存储过程⾥不能直接使⽤DDL语句,所以只能使⽤动态SQL语句来执⾏--ON COMMIT DELETE ROWS 说明临时表是事务指定,每次提交后ORACLE将截断表(删除全部⾏)--ON COMMIT PRESERVE ROWS 说明临时表是会话指定,当中断会话时ORACLE将截断表。

CREATE OR REPLACE PROCEDURE temptest(p_searchDate IN DATE)ISv_count INT;str varchar2(300);BEGINv_count := 0;str:='drop table SETT_DAILYTEST';execute immediate str;str:='CREATE GLOBAL TEMPORARY TABLE SETT_DAILYTEST (NACCOUNTID NUMBER not null,NSUBACCOUNTID NUMBER not null)ON COMMIT PRESERVE ROWS';execute immediate str; ----使⽤动态SQL语句来执⾏str:='insert into SETT_DAILYTEST (select naccountid,nsubaccountid from sett_dailyaccountbalance)'; execute immediate str;END temptest;上⾯建⽴⼀个临时表的存储过程下⾯是执⾏⼀些操作,向临时表写数据。

CREATE OR REPLACE PROCEDURE PR_DAILYCHECK(p_Date IN DATE,p_Office IN INTEGER,p_Currency IN INTEGER,P_Check IN INTEGER,p_countNum OUT INTEGER)ISv_count INT;BEGINv_count := 0;IF p_Date IS NULL THENdbms_output.put_line('⽇期不能为空');ELSEIF P_Check = 1 THENinsert into SETT_DAILYTEST (select naccountid,nsubaccountid from sett_dailyaccountbalancewhere dtdate = p_Date);selectcount(sd.naccountid) into v_countfrom sett_subaccount ss,sett_account sa,sett_dailytest sdwhere sd.naccountid = sa.id and sd.nsubaccountid = ss.id and sa.id = ss.naccountidAND sa.nofficeid = p_Office AND sa.ncurrencyid = p_Currencyand rownum < 2;COMMIT;p_countNum := v_count;dbms_output.put_line(p_countNum);END IF;IF P_Check = 2 THENinsert into SETT_DAILYTEST (select naccountid,nsubaccountid from sett_dailyaccountbalancewhere dtdate = p_Date);selectcount(sd.naccountid) into v_countfrom sett_cfsubaccount ss,sett_account sa,sett_dailytest sdwhere sd.naccountid = sa.id and sd.nsubaccountid = ss.id and sa.id = ss.naccountidAND sa.nofficeid = p_Office AND sa.ncurrencyid = p_Currencyand rownum < 2;COMMIT;p_countNum := v_count;dbms_output.put_line(p_countNum); END IF;END IF;END PR_DAILYCHECK;。

oracle 临时表写法

oracle 临时表写法

oracle 临时表写法[Oracle 临时表写法]在Oracle数据库中,临时表是一种特殊的表,用于存储临时数据,并在会话结束后自动删除。

临时表可以帮助我们在处理大量数据或需要临时存储数据的情况下提高查询性能和简化代码逻辑。

本文将一步一步介绍如何创建和使用Oracle临时表。

第一步:创建临时表在Oracle中,我们可以使用CREATE GLOBAL TEMPORARY TABLE语句创建临时表。

语法如下:CREATE GLOBAL TEMPORARY TABLE table_name(column1 datatype,column2 datatype,...)ON COMMIT PRESERVE ROWS;临时表创建语句与常规表的创建语句类似,只是在CREATE语句末尾添加了"GLOBAL TEMPORARY"关键字,并使用"ON COMMIT PRESERVEROWS"选项来指定在会话结束后是否保留表的数据。

第二步:插入数据在临时表中插入数据的方式与常规表相同。

我们可以使用INSERT INTO 语句将数据插入到临时表中。

例如:INSERT INTO table_name (column1, column2, ...)VALUES (value1, value2, ...);通过多次插入操作,我们可以向临时表中添加任意数量的数据。

第三步:使用临时表一旦我们创建并插入了数据到临时表中,就可以开始使用它了。

临时表可以作为查询的源表,也可以与常规表进行JOIN操作。

例如,我们可以使用SELECT语句从临时表中检索数据:SELECT * FROM table_name;这将返回临时表中所有数据的结果集。

我们还可以使用临时表进行JOIN操作,将其与常规表进行关联查询:SELECT t1.column1, t1.column2, ...FROM table_name_temp t1JOIN table_name_regular t2ON t1.id = t2.id;在上述示例中,我们使用了别名为t1和t2的表,将临时表和常规表进行了JOIN操作,以便根据一定的连接条件检索数据。

Oracle临时表

Oracle临时表

Oracle中临时表的使用余琦(2005-12-22)一、概念Oracle中的临时表有两种:1、事务级别的临时表按照如下方法创建:CREATE Global TEMPORARY TABLE TempTableName(bianhao varchar2(50) null) On Commit delete Rows它在事务结束的时候自动清空记录。

例如在一个存储过程或语句块里创建一个事务级的临时表,对该临时表的增加、删除、修改操作所产生的数据变化都会在调用commit命令后消失。

2、会话级的临时表按照如下方法创建:CREATE Global TEMPORARY TABLE TempTableName(bianhao varchar2(50) null) On Commit preserve Rows它在我们访问数据库时的一个会话结束后自动的清空。

连接oracle数据库的情况,当应用程序启动后,会话开始;当应用程序终止后,此会话结束。

跟我们在里所用到的系统全局变量类似,而不是跟session一样,浏览器关掉时就结束。

Windows Form程序连接oracle的情况,oracle把可执行文件启动到关闭这个过程当做一个会话。

当一个可执行文件启动后,第一次连接oracle时会话开始,可执行文件关闭时,会话结束。

二、使用方法不用担心多用户并行的问题,一个会话或事务中的临时表的数据从来不会和另外一个会话或事务中临时表的数据产生冲突。

但是我们在使用中需要注意以几点:1、事务级的临时表不能用做最后的游标返回,虽然这样的语句在数据库里测试是没有问题的,但是.net在访问的时候就会出错。

如果一定要以游标返回临时表中的数据,必须使用会话级的临时表。

2、所有的会话级的临时表不能动态去创建或删除,因为一旦创建了该临时表,除非此会话结束,否则是无法删除该临时表的。

所以我们需要在数据库初始化的时候建立系统中所有需要的会话级的临时表。

oracle建表空间语句

oracle建表空间语句

--查看当前用户的角色
select * from user_role_privs;
--修改用户口令
alter user 用户名 identified by 密码;
撤权:revoke 权限... from 用户名;
--查看表空间大小
SELECT t.tablespace_name, round(SUM(bytes / (1024 * 1024)), 0) ts_size
FROM dba_tablespaces t, dba_data_files d
WHERE t.tablespace_name = d.tablespace_name
GROUP BY t.tablespace_name;
--手动修改表空间大小
ALTER DATABASE DATAFILE 'D:\jxglyh\db\JXJCK_2013_DATA.DBF' RESIZE 10000M;
next 32m maxsize unlimited --自增 2048m
extent management local;
--创建用户与密码
create user 用户名 identified by 密码
default tablespace 表空间名
temporary tablespace 临时表空间名_temp
end loop;
close c;
end;
2、将数据库中system用户与sys用户的表导出
exp system/manager@TEST file=d:daochu.dmp owner=(system,sys)
3、将数据库中的表inner_notify notify_staff_relat导出
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

Oracle数据库临时表管理心得
我们在创建数据表的时候,若没有特殊的指明,那么我们创建的表是一个永久的关系型表格,也就是说,这个表格中对应的数据,除非是我们显示的删除的话,表中的数据是永远都存在的。

相对应的,在Oracle数据库中还有一种类型的表,叫做临时表。

这个临时表跟永久表最大的区别就是表中的数据不会永远的存在。

当一个会话结束或者事务结束的时候,这个临时表中的数据,不用用户自己删除,数据库自己会自动清
除。

1、事务临时表的管理。

(1) 事务临时表的创建。

Oracle数据库根据临时表的性质不同,可以分为事务临时表与会话临时表。

事务临时表是指数据只有在当前事务内有效。

一般情况下,如果在创建数据表的时候,没有特殊指明这表是会话临时表的话,则该表默认为事务临时表。

我们可以以下面的语句创建事务临时表。

Create global temporary table Temp_user
(ID NUMBER(12) Primary key,name varchar2(10));
笔者建议:
这个创建临时表的语句中,虽然没有显性的指明该表是事务临时表,但是,默认的情况下,若没有指明是什么临时表的话,系统默认是事务临时表。

我们要创建事务临时表时,可以不指定关键字。

但是,这查看起来比较麻烦。

我建议,无论在建立什么临时表,都要利用具体的关键字来显形的指明,这大家看起来都方便。

一般可以利用ON COMMIT DELETE ROWS关键字来说明该表就是事务性的临时表,而不是会话性质
的临时表。

(2) 事务临时表数据的变化分析。

事务临时表的话,当事务结束的时候,就会清空这个事务临时表。

所以,当我们在数据库临时表中插入数据后,只要事务没有提交的话,该表中的数据就会存在。

但是,当事务提交以后,该表中的数据就会被删除。

而且,这个变化不会在重做日志中
显示。

具体事务临时表与会话临时表有什么区别,我们在介绍完会话临时表后会详细介
绍。

2、会话临时表的管理。

会话临时表,顾名思义,是指数据只在当前会话内有效的临时表。

关闭当前会话或者进行新的连接之后,数据表中的内容就会被清除。

那会话临时表跟事务临时表到底有什么区别呢?我们以一个实例来看其中的区别。

(1) 首先,创建一个会话临时表。

CREATE GLOBAL TEMPOPARY TABLE TEMP_USER
(ID NUMBER(12) Primary key,name varchar2(10))
ON COMMIT PRESERVE ROWS;
也就是说,会话临时表跟事务临时表的创建语法大致相同,只有最后的关键字有区别。

不过两个表虽然类似,但是其内部的处理机制还是有比较大的区别。

(2) 往该表中插入数据。

Insert into TEMP_USER values(1001,’victor’);
往数据库临时表中插入数据的方法,跟往普通表中插入数据的方法是一样的,都利用insert into语句进行操作。

该临时表的数据在会话结束之前都是存在这个表格
中的。

(3) 提交该事务并查询相关记录。

我们利用COMMIT的语句把该事务提交以后,再用SELECT查询语句进行查询。

我们知道,若该表是事务临时表的话,则当该事务结束以后,该表中的内容就会被删除。

但是,这是会话临时表,所以即使该事务提交了,但是,利用SELECT语句进行查询
时,仍然可以查到该条员工记录。

(4) 结束当前会话,并重新连接数据库。

关闭当前会话,从新连接到数据库后,再利用SELECT语句查询时,会有什么结果呢?此时,就查不到我们刚才插入的数据。

这也就是说,在关闭对话的时候,数据库系统已经把原有的数据删除了。

从以上的分析我们可以看中,会话临时表与事务临时表主要的差异就在于删除数据时机的不同。

事务性临时表是在事务提交的时候清除数据,而会话性临时表则是在关闭当前会话的时候清除临时表。

只要当前会话没有关闭,即使事务完成了,会话临时表中的数据仍然存在,不会被清除。

3、临时表管理需要注意的地方。

临时表相对与其他表来说,是一种比较特殊的表结构,但是,作用又比较大,Oracle数据库若没有这种表的话,还真是不行。

为了管理好这种特殊的表,我们需要
注意几个细节。

一是要注意临时表不能永久的保存数据。

只所以称为临时表,就是因为该表中的内容只是临时存在的。

当一个会话或者事务结束时,该表中的内容就会被自动清空。

所以,在临时表中,一般不要保存永久数据。

在实务中,有个不好的操作习惯,就是有些人在测试数据库的时候,喜欢把测试的数据放在临时数据表中。

其实,这是对Oralce临时数据表认识的错误。

若我们在数据库中,把要测试的数据,如销售定单的内容放在数据库的临时表中的话,则在其他功能中,如要测试销售定单日报表的功能时,就会找不到相关的定单内容。

因为离开特定的会话或者事务的话,临时表中的内容就会不存在了。

所以,Oralce数据库中所讲的临时表不是给我们来存储测试数据的。

二是临时表中的数据不会备份、恢复,对其的修改也不会有任何的日志信息。

若我们在操作数据库的时候,往数据库的临时表中存入了一些信息。

此时突然服务器出现当机。

此时,我们想通过数据库备份文件恢复数据库临时表中的内容,或者查看临时表的日志信息,都是无法实现的。

也就是说,当服务器以外死机重新启动后,临时表中的内容就会被清空。

在数据库的任何地方,如数据库备份文件或者日志信息中,都查不到在重新启动之前数据库临时表中保存了哪些内容,就好象根本没有对临时表
进行操作一样。

三是临时表表空间的管理。

临时表在Oracle数据库中,也是表的一种,其也有对应的表空间。

在创建临时表的时候,若我们不指定表空间的话,默认的表空间是SYSTEM。

对于临时表的表空间管理的话,我们需要注意一个小的细节。

若我们把临时表的表空间归属为SYSTEM的话,也就是说,在创建临时表的时候不具体指定具体的表空间,则这个默认的表空间是不能被删除的。

而若我们在创建临时表表空间的时候,指定为SYSTEM以外的表空间的话,则在不需要这表空间的时候,我们可以删除。

所以,为了后续管理的方便,笔者还是建议大家在创建临时表的时候,要指定表空间。

四是要注意一个问题,临时表只是数据是临时的,而表仍然是永久的。

也就是说,当一个会话结束或者一个事务完成时,其临时表中的数据虽然删除了,但是,临时表本身仍然是存在的。

也就是说。

Oracle数据库中的临时表表是全局的,只是数据是临时的。

这跟SQL Server数据库系统具有比较大的区别。

其实,这两个数据库在临时表的处理上有很大的不同,各有各的特色。

在以后的文章中,我会专门叙述这两种数据库在临时表管理机制上的不同,欢迎大家关注。

五是要注意Oracle数据库在给临时表填入数据的时候,不会对相应的记录加锁。

也就是说,当在临时表上执行DML语句的操作时,不会给记录加锁,也不会将数据的变化内容写到重做(REDO)日志中。

所以不能用临时表保存永久的数据,也不能对临时表进行共同的操作。

这是新手在管理数据库临时表经常会碰到的问题。

六是临时表与普通表之间不能相互转换。

在一般情况下,临时表建立后,该表就不能被转换成永久表。

所以,这也说明一个道理,利用临时表作为数据库设计时候的
测试表不合适。

这个临时表可能跟我们按字面意思理解的临时表有误,不是我们所认为的为了测试表结构而建立的临时表。

这一点是我们在刚开始接触ORACLE数据库时,
经常会犯的错误。

相关文档
最新文档