小編給大家分享一下如何查詢過去一段時間內(nèi)某條sql使用的臨時表空間大小,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
在保靖等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務理念,為客戶提供成都網(wǎng)站設計、做網(wǎng)站 網(wǎng)站設計制作按需開發(fā),公司網(wǎng)站建設,企業(yè)網(wǎng)站建設,成都品牌網(wǎng)站建設,全網(wǎng)整合營銷推廣,外貿(mào)網(wǎng)站建設,保靖網(wǎng)站建設費用合理。
查詢過去一段時間內(nèi)使用的temp表空間大小需要查詢V$ACTIVE_SESSION_HISTORY這個視圖,SQL語句是:
select SQL_ID,
SQL_EXEC_START,
PROGRAM,
TEMP_SPACE_ALLOCATED/1024/1024/1024 from V$ACTIVE_SESSION_HISTORY where sql_id='SQL語句的sql—id' and rownum<10 order by 4;
關(guān)于v$active_session_history的解釋,大家可以根據(jù)自己的需求添加列。
V$ACTIVE_SESSION_HISTORY
顯示數(shù)據(jù)庫中的采樣會話活動。它包含每秒執(zhí)行一次的活動數(shù)據(jù)庫會話的快照。如果數(shù)據(jù)庫會話在CPU上或正在等待不屬于Idle
wait類的事件,則認為該數(shù)據(jù)庫會話是活動的。V$EVENT_NAME
有關(guān)等待類的更多信息,請參閱視圖。
此視圖為每個樣本的每個活動會話包含一行,并首先返回最新的會話樣本行。描述活動會話歷史記錄中的會話的大多數(shù)列都存在于V$SESSION
視圖中。
柱 | 數(shù)據(jù)類型 | 描述 |
---|---|---|
SAMPLE_ID | NUMBER | 樣本的ID |
SAMPLE_TIME | TIMESTAMP(3) | 采集樣品的時間 |
IS_AWR_SAMPLE | VARCHAR2(1) | 指示此樣本是否已刷新或?qū)⑺⑿碌阶詣庸ぷ髫撦d存儲庫(DBA_HIST_ACTIVE_SESS_HISTORY )(Y )或不是(N ) |
SESSION_ID | NUMBER | 會話標識; 映射到V$SESSION.SID |
SESSION_SERIAL# | NUMBER | 會話序列號(用于唯一標識會話的對象); 映射到V$SESSION.SERIAL# |
SESSION_TYPE | VARCHAR2(10) | 會話類型:
|
FLAGS | NUMBER | 保留供將來使用 |
USER_ID | NUMBER | Oracle用戶標識符; 映射到V$SESSION.USER# |
SQL_ID | VARCHAR2(13) | 在采樣時會話正在執(zhí)行的SQL語句的SQL標識符 |
IS_SQLID_CURRENT | VARCHAR2(1) | 指示SQL_ID 列中的SQL標識符是否正在執(zhí)行(Y )或不執(zhí)行(N ) |
SQL_CHILD_NUMBER | NUMBER | 在采樣時會話正在執(zhí)行的SQL語句的子編號 |
SQL_OPCODE | NUMBER | 指示SQL語句的操作階段; 映射到V$SESSION.COMMAND 另請參閱: “V $ SESSION”以獲取有關(guān)解釋此列的信息 |
SQL_OPNAME | VARCHAR2(64) | SQL命令名稱 |
FORCE_MATCHING_SIGNATURE | NUMBER | CURSOR_SHARING 參數(shù)設置為時使用的簽名FORCE |
TOP_LEVEL_SQL_ID | VARCHAR2(13) | 頂級SQL語句的SQL標識符 |
TOP_LEVEL_SQL_OPCODE | NUMBER | 指示頂級SQL語句所處的操作階段 |
SQL_PLAN_HASH_VALUE | NUMBER | 游標的SQL計劃的數(shù)字表示。此信息可能不適用于所有會話樣本。V$SESSION 不包含此信息。 |
SQL_PLAN_LINE_ID | NUMBER | SQL計劃行ID |
SQL_PLAN_OPERATION | VARCHAR2(30) | 計劃操作名稱 |
SQL_PLAN_OPTIONS | VARCHAR2(30) | 計劃操作選項 |
SQL_EXEC_ID | NUMBER | SQL執(zhí)行標識符 |
SQL_EXEC_START | DATE | SQL執(zhí)行開始的時間 |
PLSQL_ENTRY_OBJECT_ID | NUMBER | 堆棧中最頂層PL / SQL子程序的對象ID; 如果堆棧上沒有PL / SQL子程序,則為NULL。映射到DBA_OBJECTS.OBJECT_ID。 |
PLSQL_ENTRY_SUBPROGRAM_ID | NUMBER | 堆棧上最頂層PL / SQL子程序的子程序ID。映射到DBA_OBJECTS.DATA_OBJECT_ID。 |
PLSQL_OBJECT_ID | NUMBER | 當前正在執(zhí)行的PL / SQL子程序的對象ID。映射到DBA_OBJECTS.OBJECT_ID。 |
PLSQL_SUBPROGRAM_ID | NUMBER | 當前正在執(zhí)行的PL / SQL對象的子程序ID; 執(zhí)行SQL時為NULL。映射到DBA_OBJECTS.DATA_OBJECT_ID。 |
QC_INSTANCE_ID | NUMBER | 查詢協(xié)調(diào)器實例ID。僅當采樣會話是并行查詢從站時,此信息才可用。對于所有其他會話,值為。 |
QC_SESSION_ID | NUMBER | 查詢協(xié)調(diào)器會話ID。僅當采樣會話是并行查詢從站時,此信息才可用。對于所有其他會話,值為。 |
QC_SESSION_SERIAL# | NUMBER | 查詢協(xié)調(diào)器會話序列號。僅當采樣會話是并行查詢從站時,此信息才可用。對于所有其他會話,值為。 |
PX_FLAGS 腳1 | NUMBER | 保留供內(nèi)部使用 |
EVENT | VARCHAR2(64) | 如果SESSION_STATE = WAITING ,則表示會話在采樣時等待的事件。如果 另請參閱: 附錄C,“Oracle等待事件” |
EVENT_ID | NUMBER | 會話正在等待或會話最后等待的資源或事件的標識符。解釋類似于EVENT 專欄。 |
EVENT# | NUMBER | 會話正在等待或會話上次等待的資源或事件的編號。解釋類似于EVENT 專欄。 |
SEQ# | NUMBER | 唯一標識等待的序列號(每個等待增加) |
P1TEXT | VARCHAR2(64) | 第一個附加參數(shù)的文本 |
P1 | NUMBER | 第一個附加參數(shù) |
P2TEXT | VARCHAR2(64) | 第二個附加參數(shù)的文本 |
P2 | NUMBER | 第二個附加參數(shù) |
P3TEXT | VARCHAR2(64) | 第三個附加參數(shù)的文本 |
P3 | NUMBER | 第三個附加參數(shù) |
WAIT_CLASS | VARCHAR2(64) | 等待會話在采樣時等待的事件的類名。解釋類似于EVENT 專欄。地圖到V$SESSION.WAIT_CLASS 。 |
WAIT_CLASS_ID | NUMBER | 等待會話在采樣時等待的事件的類標識符。解釋類似于EVENT 專欄。地圖到V$SESSION.WAIT_CLASS_ID 。 |
WAIT_TIME | NUMBER | 會話上次等待的事件的總等待時間,如果會話在CPU上進行采樣時; 如果會話在抽樣時等待 注意:是否 |
SESSION_STATE | VARCHAR2(7) | 會話狀態(tài):
|
TIME_WAITED | NUMBER | 如果SESSION_STATE = WAITING ,那么會話實際花費在等待該事件的時間(以微秒為單位)。此列設置為采樣時正在進行的等待。如果等待事件持續(xù)超過一秒并且在多個會話樣本行中等待,則等待該等待事件所花費的實際時間將填充在這些會話樣本行的最后一行中。在任何給定時間,此信息將不適用于最新的會話樣本。 |
BLOCKING_SESSION_STATUS | VARCHAR2(11) | 阻止會話的狀態(tài):
|
BLOCKING_SESSION | NUMBER | 阻塞會話的會話標識符。僅當阻止程序位于同一實例且會話正在等待隊列或“緩沖區(qū)忙”等待時才填充。地圖到V$SESSION.BLOCKING_SESSION 。 |
BLOCKING_SESSION_SERIAL# | NUMBER | 阻止會話的序列號 |
BLOCKING_INST_ID | NUMBER | 顯示的阻止程序的實例編號 BLOCKING_SESSION |
BLOCKING_HANGCHAIN_INFO | VARCHAR2(1) | 指示有關(guān)的信息BLOCKING_SESSION 是來自掛起鏈(Y )還是不來自(N ) |
CURRENT_OBJ# | NUMBER | 會話引用的對象的對象ID。僅當會話正在等待應用程序,群集,并發(fā)和用戶I / O等待事件時,此信息才可用。地圖到V$SESSION.ROW_WAIT_OBJ# 。 |
CURRENT_FILE# | NUMBER | 包含會話引用的塊的文件的文件號。僅當會話正在等待群集,并發(fā)和用戶I / O等待事件時,此信息才可用。地圖到V$SESSION.ROW_WAIT_FILE# 。 |
CURRENT_BLOCK# | NUMBER | 會話引用的塊的ID。僅當會話正在等待群集,并發(fā)和用戶I / O等待事件時,此信息才可用。地圖到V$SESSION.ROW_WAIT_BLOCK# 。 |
CURRENT_ROW# | NUMBER | 會話引用的行標識符。僅當會話正在等待群集,并發(fā)和用戶I / O等待事件時,此信息才可用。地圖到V$SESSION.ROW_WAIT_ROW# 。 |
TOP_LEVEL_CALL# | NUMBER | Oracle頂級電話號碼 |
TOP_LEVEL_CALL_NAME | VARCHAR2(64) | Oracle頂級呼叫名稱 |
CONSUMER_GROUP_ID | NUMBER | 消費者組ID |
XID | RAW(8) | 會話在采樣時正在處理的事務ID。V$SESSION 不包含此信息。 |
REMOTE_INSTANCE# | NUMBER | 遠程實例標識符,用于為此會話等待的塊提供服務。此信息僅在會話等待群集事件時可用。 |
TIME_MODEL | NUMBER | 時間模型信息 |
IN_CONNECTION_MGMT | VARCHAR2(1) | 指示會話在采樣時是否正在進行連接管理(Y )或不是(N ) |
IN_PARSE | VARCHAR2(1) | 指示會話在采樣時是否正在解析(Y )或不是(N ) |
IN_HARD_PARSE | VARCHAR2(1) | 指示在sampling(Y )或不是(N )時會話是否難以解析 |
IN_SQL_EXECUTION | VARCHAR2(1) | 指示會話是否在sampling(Y )或不執(zhí)行時執(zhí)行SQL語句(N ) |
IN_PLSQL_EXECUTION | VARCHAR2(1) | 指示會話是否在sampling(Y )或不執(zhí)行時執(zhí)行PL / SQL (N ) |
IN_PLSQL_RPC | VARCHAR2(1) | 指示會話是否在sampling(Y )或不執(zhí)行時執(zhí)行入站PL / SQL RPC調(diào)用(N ) |
IN_PLSQL_COMPILATION | VARCHAR2(1) | 指示會話是在編譯時是否正在編譯PL / SQL(Y )或不是(N ) |
IN_JAVA_EXECUTION | VARCHAR2(1) | 指示會話是否在sampling(Y )或不執(zhí)行時執(zhí)行Java (N ) |
IN_BIND | VARCHAR2(1) | 指示會話是否在sampling(Y )或不執(zhí)行時執(zhí)行綁定操作(N ) |
IN_CURSOR_CLOSE | VARCHAR2(1) | 指示會話是否在sampling(Y )或不是(N )時關(guān)閉游標 |
IN_SEQUENCE_LOAD | VARCHAR2(1) | 指示會話是按順序加載(按順序加載代碼)(Y )還是不加載(N ) |
CAPTURE_OVERHEAD | VARCHAR2(1) | 指示會話是否正在執(zhí)行捕獲代碼(Y )或不執(zhí)行(N ) |
REPLAY_OVERHEAD | VARCHAR2(1) | 指示會話是否正在執(zhí)行重放代碼(Y )或不執(zhí)行(N ) |
IS_CAPTURED | VARCHAR2(1) | 指示是否正在捕獲會話(Y )或不捕獲(N ) |
IS_REPLAYED | VARCHAR2(1) | 指示會話是否正在重播(Y )或不重播(N ) |
SERVICE_HASH | NUMBER | 標識服務的哈希值; 映射到V$ACTIVE_SERVICES.NAME_HASH |
PROGRAM | VARCHAR2(48) | 操作系統(tǒng)程序的名稱 |
MODULE 腳2 | VARCHAR2(48) | 采樣時執(zhí)行模塊的名稱,由DBMS_APPLICATION_INFO.SET_MODULE 過程設置 |
ACTION Footref 2 | VARCHAR2(32) | 采樣時執(zhí)行模塊的名稱,由DBMS_APPLICATION_INFO.SET_ACTION 過程設置 |
CLIENT_ID | VARCHAR2(64) | 會話的客戶標識符; 映射到V$SESSION.CLIENT_IDENTIFIER |
MACHINE | VARCHAR2(64) | 客戶端的操作系統(tǒng)機器名稱 |
PORT | NUMBER | 客戶端端口號 |
ECID | VARCHAR2(64) | 執(zhí)行上下文標識符(由Application Server發(fā)送) |
DBREPLAY_FILE_ID Footref 1 | NUMBER | 如果正在捕獲或重放會話,那么DBREPLAY_FILE_ID 是工作負載捕獲或工作負載重放的文件ID; 否則它是NULL。 |
DBREPLAY_CALL_COUNTER Footref 1 | NUMBER | 如果正在捕獲或重放會話,則是正在捕獲或重放DBREPLAY_CALL_COUNTER 的用戶呼叫的呼叫計數(shù)器; 否則它是NULL。 |
TM_DELTA_TIME | NUMBER | 在其時間間隔(以微秒計)TM_DELTA_CPU_TIME 和TM_DELTA_DB_TIME 被累積 |
TM_DELTA_CPU_TIME | NUMBER | 此會話在過去TM_DELTA_TIME 幾微秒內(nèi)花在CPU上的時間 |
TM_DELTA_DB_TIME | NUMBER | 此會話在過去TM_DELTA_TIME 幾微秒內(nèi)在數(shù)據(jù)庫調(diào)用中花費的時間 |
DELTA_TIME | NUMBER | 自上次采樣或創(chuàng)建會話以來的時間間隔(以微秒為單位),累計接下來的五個統(tǒng)計信息 |
DELTA_READ_IO_REQUESTS | NUMBER | 此會話在過去DELTA_TIME 幾微秒內(nèi)發(fā)出的讀取I / O請求數(shù) |
DELTA_WRITE_IO_REQUESTS | NUMBER | 此會話在過去DELTA_TIME 幾微秒內(nèi)發(fā)出的寫入I / O請求數(shù) |
DELTA_READ_IO_BYTES | NUMBER | 此會話在過去DELTA_TIME 幾微秒內(nèi)讀取的I / O字節(jié)數(shù) |
DELTA_WRITE_IO_BYTES | NUMBER | 此會話在過去DELTA_TIME 幾微秒內(nèi)寫入的I / O字節(jié)數(shù) |
DELTA_INTERCONNECT_IO_BYTES | NUMBER | 在過去DELTA_TIME 幾微秒內(nèi)通過I / O互連發(fā)送的I / O字節(jié)數(shù) |
PGA_ALLOCATED | NUMBER | 此示例拍攝時此會話占用的PGA內(nèi)存量(以字節(jié)為單位) |
TEMP_SPACE_ALLOCATED | NUMBER | 拍攝此樣本時此會話消耗的TEMP內(nèi)存量(以字節(jié)為單位) |
看完了這篇文章,相信你對“如何查詢過去一段時間內(nèi)某條sql使用的臨時表空間大小”有了一定的了解,如果想了解更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!