|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
MySQL部署迅速,因此移植过程不会导致生产中断。而且,较短的学习曲线可以让你的系统管理员迅速掌握它的运行和维护。而且,MySQL的易于维护和管理意味着目前的职员可以处理目前的工作。oracle|一时表
申明:下文中的一些申明和示例代码摘自CSDN,恕纷歧一指明出处,在此一并对相干作者暗示感激!假如作者有贰言,请来信申明
1语法在Oracle中,能够创立以下两种一时表:
1)会话独有的一时表
CREATEGLOBALTEMPORARY<TABLE_NAME>(<columnspecification>)
ONCOMMITPRESERVEROWS;
2)事件独有的一时表
CREATEGLOBALTEMPORARY<TABLE_NAME>(<columnspecification>)
ONCOMMITDELETEROWS;
CREATEGLOBALTEMPORARYTABLEMyTempTable
所建的一时表固然是存在的,可是假如insert一笔记录然后用其余毗连登上往select,纪录是空的。
--ONCOMMITDELETEROWS申明一时表是事件指定,每次提交后ORACLE将截断表(删除全体行)
--ONCOMMITPRESERVEROWS申明一时表是会话指定,傍边断会话时ORACLE将截断表。
2静态创立
createorreplaceprocedurepro_temp(v_col1varchar2,v_col2varchar2)as
v_numnumber;
begin
selectcount(*)intov_numfromuser_tableswheretable_name=T_TEMP;
--createtemporarytable
ifv_num<1then
executeimmediateCREATEGLOBALTEMPORARYTABLET_TEMP(
COL1VARCHAR2(10),
COL2VARCHAR2(10)
)ONCOMMITdeleteROWS;
endif;
--insertdata
executeimmediateinsertintot_tempvalues(||v_col1||,||v_col2||);
executeimmediateselectcol1fromt_tempintov_num;
dbms_output.put_line(v_num);
executeimmediatedeletefromt_temp;
commit;
executeimmediatedroptablet_temp;
endpro_temp;
测试:
15:23:54SQL>setserveroutputon
15:24:01SQL>execpro_temp(11,22);
11
PL/SQL历程已乐成完成。
已用工夫:00:00:00.79
15:24:08SQL>desct_temp;
ERROR:
ORA-04043:工具t_temp不存在
3特征和功能(与一般表和视图的对照)一时表只在以后毗连内无效一时表不创建索引,以是假如数据量对照年夜或举行屡次查询时,不保举利用数据处置对照庞大的时分时表快,反之视图快点在仅仅查询数据的时分倡议用游标:opencursorforsqlclause;
接待增补!
客户还是可以使用DBaaS系统所能提供的所有能力。数据库云服务消除了组织对专职人员、本地数据库存储设备的需要。他们不必安装、配置和维护任何软硬件。 |
|