oracle臨時表的經典學習資料
---->>轉載於:http://blog.csdn.net/wyzxg/article/details/1882347
前段時間,新公司的面試官問了一個問題,臨時表的作用,以前我們用快取中間資料時候,都是自己建一個臨時表。其實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.例子:略
4.臨時表的不足之處
1)不支援lob物件,這也許是設計者基於執行效率的考慮,但實際應用中確實需要此功能時就無法使用臨時表了。
2)不支援主外來鍵關係
所以,由於以上原因,我們可以自己建立臨時表,以彌補oracle臨時表的不足之處
上面的都是本人經過測試的,但下面是在網上搜尋到的方法,本人具體沒有測試過,不過覺得可行性很強,有時間測試下
建立方法:
1、以常規表的形式建立臨時資料表的表結構,但要在每一個表的主鍵中加入一個 SessionID
2、寫一個使用者登出觸發器,在使用者結束會話的時候刪除本次會話所插入的所有記錄(SessionID等於本次會話ID的記錄)。
3、程式寫入資料時,要順便將當前的會話ID(SessionID)寫入表中。
4、程式讀取資料時,只讀取與當前會話ID相同的記錄即可。
功能增強的擴充套件設計:
1、可以在資料表上建立一個檢視,檢視對記錄的篩選條件就是當前會話的SessionID。
2、資料表中的SessionID列可以透過Trigger實現,以實現對應用層的透明性。
3、高階使用者可以訪問全域性資料,以實現更加複雜的功能。
擴充套件臨時表的優點:
1、實現了與Oracle的基於會話的臨時表相同的功能。
2、支援SDO_GEOMETRY等lob資料型別。
3、支援表間的主外來鍵連線,且主外來鍵連線也是基於會話的。
4、高階使用者可以訪問全域性資料,以實現更加複雜的功能
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29119536/viewspace-1098802/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- oracle 臨時表的使用Oracle
- Oracle臨時表空間檢視、新增臨時表空間資料檔案、修改預設臨時表空間 方法!Oracle
- 大資料經典學習路線大資料
- ORACLE臨時表總結Oracle
- 大資料經典學習路線,必看!!大資料
- oracle建立臨時表空間和資料表空間以及刪除Oracle
- Oracle 臨時表 OracleDataAdapter 批次更新OracleAPT
- Oracle臨時表的用法總結FLOracle
- oracle臨時表空間相關Oracle
- Oracle臨時表使用注意事項Oracle
- 資料新時代已經來臨
- Oracle資料檔案和臨時檔案的管理Oracle
- 大資料經典學習路線(及供參考)大資料
- 大資料學習計劃【2019經典不斷更新】大資料
- oracle 臨時表空間的增刪改查Oracle
- MYSQL造資料佔用臨時表空間MySql
- 資料庫優化之臨時表優化資料庫優化
- 資料庫臨時表有舍才有得DP資料庫
- 檢視oracle臨時表空間佔用率的檢視Oracle
- 字串函式庫的經典使用學習字串函式
- oracle11g 查詢臨時表空間的使用率和正在使用臨時表空間的使用者Oracle
- SQLServer臨時表的使用SQLServer
- MySQL 中的臨時表MySql
- oracle 9i臨時表產生過多redoOracle
- Oracle資料庫表設計時的注意事項Oracle資料庫
- PostgreSQL:臨時表SQL
- MySQL臨時表MySql
- SQL Server通過建立臨時表遍歷更新資料SQLServer
- [20190410]dg建立臨時表檔案資料檔案.txt
- Deep Crossing模型——經典的深度學習架構ROS模型深度學習架構
- 聊聊經典機器學習入門機器學習
- 故障分析 | MySQL 5.7 使用臨時表導致資料庫 CrashMySql資料庫
- mysql 建立臨時表MySql
- MySQL之臨時表MySql
- 大資料時代來臨大資料
- 大資料如何學習,大資料工程師學習經驗分享大資料工程師
- 【機器學習】深度學習與經典機器學習的優劣勢一覽機器學習深度學習
- 網路表述學習經典論文——DeepWalk
- 深度學習經典卷積神經網路之AlexNet深度學習卷積神經網路