group by 需要排序嗎?
研究了一下,group by是否排序是受隱含引數_gby_hash_aggregation_enabled控制的,如下測試:
從10g之後,group by預設採用了hash group by,不再排序了。
SQL> alter system set "_gby_hash_aggregation_enabled"=false;
System altered.
SQL> set autot traceonly
SQL> select object_type,max(object_name) from test group by object_type;
41 rows selected.
Execution Plan
----------------------------------------------------------
Plan hash value: 2603667166
---------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
---------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 380K| 27M| 1262 (2)| 00:00:16 |
| 1 | SORT GROUP BY | | 380K| 27M| 1262 (2)| 00:00:16 |
| 2 | TABLE ACCESS FULL| TEST | 380K| 27M| 1250 (1)| 00:00:15 |
---------------------------------------------------------------------------
Note
-----
- dynamic sampling used for this statement
Statistics
----------------------------------------------------------
5 recursive calls
0 db block gets
5683 consistent gets
0 physical reads
0 redo size
2019 bytes sent via SQL*Net to client
421 bytes received via SQL*Net from client
4 SQL*Net roundtrips to/from client
1 sorts (memory)
0 sorts (disk)
41 rows processed
SQL> alter system set "_gby_hash_aggregation_enabled"=true;
System altered.
SQL> select object_type,max(object_name) from test group by object_type;
41 rows selected.
Execution Plan
----------------------------------------------------------
Plan hash value: 1435881708
---------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
---------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 3061K| 224M| 1379 (10)| 00:00:17 |
| 1 | HASH GROUP BY | | 3061K| 224M| 1379 (10)| 00:00:17 |
| 2 | TABLE ACCESS FULL| TEST | 3061K| 224M| 1273 (3)| 00:00:16 |
---------------------------------------------------------------------------
Note
-----
- dynamic sampling used for this statement
Statistics
----------------------------------------------------------
0 recursive calls
0 db block gets
5612 consistent gets
0 physical reads
0 redo size
1995 bytes sent via SQL*Net to client
421 bytes received via SQL*Net from client
4 SQL*Net roundtrips to/from client
0 sorts (memory)
0 sorts (disk)
41 rows processed
從10g之後,group by預設採用了hash group by,不再排序了。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10972173/viewspace-742876/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- group by 排序問題排序
- SQL 分組排序group bySQL排序
- group by 不一定排序排序
- mysql使用group by實現組內排序實戰MySql排序
- group by排序,derived_merge優化的坑排序優化
- 遊戲需要演出嗎?遊戲
- group by排序,derived_merge最佳化的坑排序
- mongodb常用的兩種group方法,以及對結果排序MongoDB排序
- mac需要關機嗎Mac
- Mysql優化_ORDER BY和GROUP BY 的優化講解(單路排序和雙路排序)MySql優化排序
- mongodb需要配ssd卡嗎?MongoDBSD卡
- mac需要裝python嗎MacPython
- MySQL 預設排序真的是按主鍵來排序的嗎MySql排序
- 學習Python需要培訓嗎?可以自學嗎?Python
- 你真的需要新款MacBook Pro嗎?Mac
- Scrum Master需要技術背景嗎?ScrumAST
- 你需要每天寫程式碼嗎?
- 你真的需要定期重灌Windows嗎?Windows
- Python需要配置檔案嗎?Python
- 專案管理需要懂業務嗎?專案管理
- 堆排序你真的學會了嗎?排序
- oracle文件中關於group by語句不保證排序正確的描述Oracle排序
- Linux需要防毒軟體嗎?存在安全隱患嗎?Linux防毒
- 新手學Python可行嗎?需要什麼基礎嗎?Python
- MAC需要安裝防毒軟體嗎Mac防毒
- flutter 地圖外掛 有人需要嗎?Flutter地圖
- 你需要託管資料庫嗎?資料庫
- 香港伺服器需要備案嗎?伺服器
- http需要申請ssl證書嗎?HTTP
- 您的系統真的需要EJB嗎?
- C#:我們需要它嗎? (轉)C#
- 排序演算法你學會了嗎?排序演算法
- Python需要懂英語嗎?英語基礎很重要嗎?Python
- 做資料分析需要學習機器學習嗎?機器學習
- 發售遊戲需要挑選“黃道吉日”嗎?遊戲
- 我的網站需要SSL證書嗎?網站
- Python學習需要多久?自學可以嗎?Python
- 我們需要使用CRM系統嗎?