自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

正排倒排,并不是 MySQL 的排序的全部!

數(shù)據(jù)庫(kù) MySQL
“正排倒排,當(dāng)然不是全部,你最少要知道,2個(gè)參數(shù),1個(gè)優(yōu)化,一種特殊情況”。

 [[407094]]

引言

春節(jié)前一個(gè)悠閑的上午,小航送了我,一袋堅(jiān)果,他看我吃的正香,慢慢問(wèn)道:”溫哥,mysql的排序,有什么要注意的嗎,不就是正排倒排嗎?”

我一聽他問(wèn)我的問(wèn)題,頓感堅(jiān)果不香了,但是為了技術(shù)(mainzi),我裝作大師的說(shuō)道:

“正排倒排,當(dāng)然不是全部,你最少要知道,2個(gè)參數(shù),1個(gè)優(yōu)化,一種特殊情況”

注:東西不能亂吃啊

兩個(gè)核心參數(shù)

sort_buffer_size 決定內(nèi)排,外排。內(nèi)排就是走內(nèi)存,外排就是采用歸并排序走磁盤。

max_length_for_sort_data 決定 全字段排序還是,rowid排序。

全字段排序

字段都放到 sort_buffer 中,排序后就會(huì)直接從內(nèi)存里面返回查詢結(jié)果了

Rowid排序

內(nèi)存放rowid與排序字段,排序后,再?gòu)膸?kù)中找數(shù)據(jù),拼接返回。

優(yōu)化手段覆蓋索引

覆蓋索引是指,索引上的信息足夠滿足查詢請(qǐng)求,不需要再回到主鍵索引上去取數(shù)據(jù)。另外,MySQL 系列面試題和答案全部整理好了,微信搜索Java技術(shù)棧,在后臺(tái)發(fā)送:面試,可以在線閱讀。

例子 

  1. explain  
  2. SELECT order_id,pay_date FROM orders_detail WHERE order_id='1001' ORDER BY pay_date asc 

用到了filesort,也就是需要排序。《MySQL 開發(fā)的 36 條軍規(guī)》推薦看下。

調(diào)整索引 

  1. ALTER TABLE `orders_detail` DROP INDEX `order_id`,ADD INDEX `order_id` (`order_id`, `pay_date`); 

之后 

  1. explain  
  2. SELECT order_id,pay_date FROM orders_detail WHERE order_id='1001' ORDER BY pay_date asc 

沒有用到filesort,因?yàn)閺?fù)合索引,字段后是有序的。

特殊情況 Order by+ Limit

Limit可能用到優(yōu)先隊(duì)列排序算法。

例子:

    1.  開啟優(yōu)化追蹤 

  1. SET OPTIMIZER_TRACE="enabled=on",END_MARKERS_IN_JSON=off 
  2. SET optimizer_trace_offset=-30, optimizer_trace_limit=30

    2.  查看字段索引 

  1. SHOW INDEX FROM oc_order_online WHERE COLUMN_NAME='order_name'

結(jié)果顯示沒有索引

    3.  執(zhí)行order by+limit 查詢語(yǔ)句 

  1. select * from `oc_order_online`  order by  `order_name`  limit 20 

    4.  查詢優(yōu)化追蹤信息 

  1. SELECT * FROM INFORMATION_SCHEMA.OPTIMIZER_TRACE limit 30 

對(duì)應(yīng)結(jié)果如下:

查詢將紅框中數(shù)據(jù),粘貼到j(luò)son.cn查看格式化數(shù)據(jù),有如下片段

filesort_priority_queue_optimization 中的chosen:true表示使用了優(yōu)先隊(duì)列排序。另外,關(guān)注公眾號(hào)Java技術(shù)棧,在后臺(tái)回復(fù):面試,可以獲取我整理的 Java 系列面試題和答案,非常齊全。

總結(jié)

  1.  sort_buffer_size 決定內(nèi)排,外排
  2.  max_length_for_sort_data 決定 全字段排序還是,rowid排序
  3.  覆蓋索引是一種優(yōu)化手段
  4.  Limit可能涉及優(yōu)先隊(duì)列排序 

 

責(zé)任編輯:龐桂玉 來(lái)源: Java技術(shù)棧
相關(guān)推薦

2017-10-18 22:18:09

2022-03-13 23:19:04

元宇宙區(qū)塊鏈數(shù)字貨幣

2015-05-08 07:29:42

OpenStack云方案云服務(wù)成本

2021-07-15 06:43:12

SQLSelect命令

2011-07-26 13:47:06

AndroidLinux

2015-12-17 11:04:00

云開支云計(jì)算

2009-04-28 09:13:27

MySQLOracle收購(gòu)

2011-07-28 09:45:59

云計(jì)算

2011-08-31 15:52:26

微軟

2010-07-21 09:21:10

云計(jì)算

2018-02-25 19:20:13

軟件定義SD-WAN廣域網(wǎng)

2022-06-14 18:35:01

ID生成器語(yǔ)言

2022-05-05 09:17:03

文檔開源

2013-05-02 16:21:26

APP

2023-06-25 20:07:57

云計(jì)算

2010-06-10 14:49:07

協(xié)議轉(zhuǎn)換器

2021-06-11 09:23:30

微服務(wù)架構(gòu)分層架構(gòu)

2018-11-27 14:57:00

IPv6IPv4網(wǎng)絡(luò)

2022-07-11 13:34:13

數(shù)據(jù)歸檔

2013-07-31 09:45:03

產(chǎn)品經(jīng)理用戶體驗(yàn)效果
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)