oracle臨時表的用法
1、前言
目前所有使用Oracle作為資料庫支撐平臺的應用,大部分資料量比較龐大的系統,即表的資料量一般情況下都是在百萬級以上的資料量。
當然在Oracle中建立分割槽是一種不錯的選擇,但是當你發現你的應用有多張表關聯的時候,並且這些表大部分都是比較龐大,而你關聯的時候發現其中的某一張或者某幾張表關聯之後得到的結果集非常小並且查詢得到這個結果集的速度非常快,那麼這個時候我考慮在Oracle中建立“臨時表”。
我對臨時表的理解:在Oracle中建立一張表,這個表不用於其他的什麼功能,主要用於自己的軟體系統一些特有功能才用的,而當你用完之後表中的資料就沒用了。Oracle的臨時表建立之後基本不佔用表空間,如果你沒有指定臨時表(包括臨時表的索引)存放的表空的時候,你插入到臨時表的資料是存放在ORACLE系統的臨時表空間中(TEMP)。
2、臨時表的建立
建立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或者是會話結束,臨時表中的資料都將被截斷
4)什麼時候使用臨時表
1)、當某一個SQL語句關聯的表在2張及以上,並且和一些小表關聯。可以採用將大表進行分拆並且得到比較小的結果集合存放在臨時表中
2)、程式執行過程中可能需要存放一些臨時的資料,這些資料在整個程式的會話過程中都需要用的等等。
3.臨時表的不足之處
1)不支援lob物件,這也許是設計者基於執行效率的考慮,但實際應用中確實需要此功能時就無法使用臨時表了。
2)不支援主外來鍵關係
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/16860121/viewspace-713009/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Oracle臨時表的用法總結FLOracle
- oracle 臨時表的使用Oracle
- ORACLE臨時表總結Oracle
- 關於with 臨時表 as的一些用法
- Oracle 臨時表 OracleDataAdapter 批次更新OracleAPT
- Oracle臨時表使用注意事項Oracle
- oracle臨時表空間相關Oracle
- oracle 臨時表空間的增刪改查Oracle
- Oracle臨時表空間檢視、新增臨時表空間資料檔案、修改預設臨時表空間 方法!Oracle
- 檢視oracle臨時表空間佔用率的檢視Oracle
- oracle11g 查詢臨時表空間的使用率和正在使用臨時表空間的使用者Oracle
- oracle 9i臨時表產生過多redoOracle
- SQLServer臨時表的使用SQLServer
- MySQL 中的臨時表MySql
- MySQL臨時表MySql
- PostgreSQL:臨時表SQL
- oracle建立臨時表空間和資料表空間以及刪除Oracle
- MySQL之臨時表MySql
- mysql 建立臨時表MySql
- MySQL 5.7 新特性 共享臨時表空間及臨時表改進MySql
- mysql臨時表,臨時表空間,ibtmp1表空間暴增原因初探MySql
- Oracle日常問題-臨時表過多導致exp速度慢Oracle
- Oracle 12C RMAN備份佔用大量臨時表空間Oracle
- Oracle 查詢佔用臨時表空間大的歷史會話和SQLOracle會話SQL
- mysql關於臨時表的總結MySql
- Oracle 12CR2查詢轉換之cursor-duration臨時表Oracle
- 消除臨時表空間暴漲的方法
- MySQL8.0新特性-臨時表的改善MySql
- Sqlserver 關於臨時表和表變數的總結SQLServer變數
- Oracle資料檔案和臨時檔案的管理Oracle
- oracle comment on的用法Oracle
- oracle建立使用者,表空間,臨時表空間,分配許可權步驟詳解Oracle
- [20181108]with temp as 建立臨時表嗎.txt
- 4.2.1.8規劃臨時表空間
- 刪除臨時表空間組
- MySQL InnoDB臨時表空間配置MySql
- mysql複製中臨時表的運用技巧MySql
- 2.5.7 建立預設臨時表空間
- 清理臨時表規範以及指令碼指令碼