【SQL】Oracle SQL處理的流程
本文主要介紹Oracle SQL處理的流程
1.概述
下圖描述了Oracle資料庫如何處理sql的一個流程,根據需求不同,可能會省略某個部分
1.1 SQL解析
當應用程式發出SQL語句時,應用程式對資料庫進行解析呼叫,以準備執行該語句。parse呼叫開啟或建立一個遊標,該遊標是特定於會話的私有SQL區域的控制程式碼,該區域儲存已解析的SQL語句和其他處理資訊。遊標和專用SQL區域位於程式全域性區域(PGA)中。
解析包括語法解析、語義檢查(含義)、共享池檢查(硬解析/軟解析之類)。 SQL共享池檢查,請參考其他文件。
1.2 SQL優化
在優化期間,Oracle 資料庫必須對每個唯一的 DML 語句至少執行一次硬解析,並在此解析期間執行優化。
1.3 SQL行源生成
行源生成器是從優化器接收最佳執行計劃並生成可供資料庫其餘部分使用的迭代執行計劃的軟體。
迭代計劃是一個二進位制程式,當由SQL引擎執行時,生成結果集。該計劃採取了一系列步驟的組合形式。每一步都返回一個行集。下一步使用該集中的行,或者最後一步將這些行返回給發出SQL語句的應用程式。
行源是執行計劃中的步驟返回的行集,以及可以迭代處理行的控制結構。行源可以是表、檢視或聯接或分組操作的結果。
行源生成器生成一個行源樹,它是行源的集合。
行源樹顯示以下資訊:
•對該宣告引用的表格進行排序
•宣告中提到的每個表的訪問方法
•語句中受聯接操作影響的表的聯接方法
•資料操作,如篩選、排序或聚合
1.4 SQL執行
在執行過程中,如果資料不在記憶體中,則資料庫將資料從磁碟讀取到記憶體中。資料庫還取出確保資料完整性所需的任何鎖和閂鎖,並記錄在 SQL 執行期間所做的任何更改。處理 SQL 語句的最後階段是關閉遊標。
2.Oracle如何處理DML
2.1獲取行集
大多數 DML 語句都有一個查詢元件。在查詢中,遊標的執行將查詢結果放入一組稱為結果集的行中。
在提取階段,資料庫選擇行,如果查詢請求,則對行進行排序。每次連續提取都會檢索另一行結果,直到提取到最後一行。
通常,在獲取最後一行之前,資料庫無法確定某個查詢要檢索的行數。Oracle 資料庫檢索資料以響應 fetch 呼叫,因此資料庫讀取的行越多,它執行的工作就越多。對於某些查詢,資料庫儘可能快地返回第一行,而對於其他查詢,它在返回第一行之前建立整個結果集。
2.2 讀一致性
一般情況下,查詢通過Oracle 資料庫讀取一致性機制來檢索資料,該機制保證查詢讀取的所有資料塊在單個時間點上是一致的。
讀取一致性使用撤消資料來顯示資料的過去版本。例如,假設查詢必須在全表掃描中讀取 100 個資料塊。查詢處理前 10 個塊,而不同會話中的 DML 修改塊 75。當第一個會話到達塊 75 時,它實現更改並使用撤消資料檢索舊的、未修改的資料版本並構造塊的非當前版本75 在記憶體中。
2.3 資料更改
必須更改資料的 DML 語句使用讀取一致性來僅檢索在修改開始時與搜尋條件匹配的資料。
之後,這些語句檢索當前狀態中存在的資料塊並進行所需的修改。資料庫必須執行與資料修改相關的其他操作,例如生成重做和撤消資料。
3.Oracle如何處理DDL
Oracle 資料庫處理 DDL 的方式與 DML 不同。
例如,建立表時,資料庫不會優化CREATE TABLE語句。相反,Oracle 資料庫解析 DDL 語句並執行命令。
資料庫處理 DDL 的方式不同,因為它是在資料字典中定義物件的一種方式。通常,Oracle 資料庫必須解析和執行許多遞迴 SQL語句才能執行 DDL 語句
CREATE TABLE mytable (mycolumn INTEGER);
通常,資料庫會執行幾十個遞迴語句來執行上面的語句。遞迴 SQL 將執行如下操作:
-
COMMIT在執行CREATE TABLE語句 之前發出 a
-
驗證使用者許可權是否足以建立表
-
確定表應該駐留在哪個表空間
-
確保沒有超過表空間配額
-
確保架構中沒有物件具有相同的名稱
-
將定義表的行插入到資料字典中
-
如果DDL語句成功,則發出COMMIT;如果未成功,則發出ROLLBACK
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29487349/viewspace-2790797/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Oracle SQL處理OracleSQL
- Oracle sql 語句中帶有特殊的字元處理OracleSQL字元
- sql server對於日期的處理SQLServer
- Transact-SQL處理小數SQL
- SQL Server 異常程式碼處理SQLServer
- 使用Sql插入sde是ObjectId的處理方式SQLObject
- sql 預處理為什麼可以放置SQL隱碼攻擊SQL
- 【SQL】Oracle SQL共享池檢查SQLOracle
- SQL中的常用的字串處理函式大全SQL字串函式
- Oracle PL/SQLOracleSQL
- Oracle中的sql hintOracleSQL
- Oracle Gateway for SQL Server時2PC分散式事務異常處理OracleGatewaySQLServer分散式
- 那些年,我們處理過的SQL問題SQL
- SQL Server2008程式堵塞處理方法SQLServer
- CSRF, XSS, Sql注入原理和處理方案SQL
- SQL server 特殊字元"u0000"處理SQLServer字元
- Oracle SQL精妙SQL語句講解OracleSQL
- Oracle SQL優化之sql tuning advisorOracleSQL優化
- Oracle - 執行過的SQL、正在執行的SQL、消耗資源最多的SQLOracleSQL
- 【SQL】Oracle 19c SQL隔離詳解(SQL Quarantine)SQLOracle
- sql(oracle)資料處理實用總結開窗函式(over partition)使用SQLOracle函式
- oracle常用後臺程序及sql語句執行流程OracleSQL
- Oracle 10046 SQL TRACEOracleSQL
- Hacking Oracle with Sql InjectionOracleSQL
- Oracle SQL Model ClauseOracleSQL
- [ORACLE] SQL執行OracleSQL
- [Oracle]Oracle良性SQL建議OracleSQL
- Oracle SQL調優系列之SQL Monitor ReportOracleSQL
- 利用SQL Profiler處理開銷較大的查詢SQL
- Clickhouse SQL日期處理函式及案例分享SQL函式
- oracle SQL最佳化器SQL Tuning Advisor (STA)OracleSQL
- 【TUNE_ORACLE】列出索引被哪些SQL引用的SQL參考Oracle索引SQL
- Oracle優化案例-緊急處理一條sql引起cpu使用率99%的問題(十六)Oracle優化SQL
- T-SQL:事務鎖下的併發處理(十五)SQL
- Oracle 的PL/SQL語言使用OracleSQL
- PostgreSQL與Oracle的sql差異SQLOracle
- Spark SQL:實現日誌離線批處理SparkSQL
- 使用spark-sql處理Doris大表關聯SparkSQL