首页
/
每日頭條
/
生活
/
mysql生成随機函數
mysql生成随機函數
更新时间:2025-07-02 10:53:14

CREATE TABLE `words` ( `id` int(11) NOT NULL AUTO_INCREMENT, `word` varchar(64) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB; delimiter ;; create procedure idata() begin declare i int; set i=0; while i<10000 do insert into words(word) values(concat(char(97 (i div 1000)), char(97 (i % 1000 div 100)), char(97 (i % 100 div 10)), char(97 (i % 10)))); set i=i 1; end while; end;; delimiter ; call idata();

如何随機取3個單詞

select word from words order by rand() limit 3; -- 查看上面語句的執行情況 explain select word from words order by rand() limit 3;

mysql生成随機函數(MySQL随機函數RAND)1

Extra中Using temporary表示使用臨時表,Using filesort表示需要執行排序操作。

上述默認使用的臨時表是内存表,對于内存表來說,回表過程隻是簡單地根據數據行的位置直接訪問内存得到數據,并不會導緻額外的磁盤訪問,因此MySQL會在排序時會優先使用rowid排序。

上述SQL語句的執行過程如下:

  1. 創建一個臨時表(該表使用的是memory引擎),表裡有兩個字段,第一個字段是double類型(記為字段R),第二個字段是varchar(64)類型(記為字段W),臨時表沒有索引
  2. 從word表中,按照主鍵順序取出所有的word值,對于每一個word值,調用rand函數生成一個大于0小于1的随機小數,把該随機小數和word值存入臨時表的R和W字段中,至此掃描行數是10000
  3. 臨時表目前有10000行數據,下面需要對這個臨時表按照字段R進行排序
  4. 初始化sort_buffer,sort_buffer中有兩個字段,一個是double類型,另一個是整型
  5. 從内存臨時表中逐行取出R值和位置信息,分别存入sort_buffer中的兩個字段,此時掃描行數又增加了10000行,變成了20000(MySQL8.0.12以後這裡還是10000行,應該是對内存表做了優化,有知道的朋友可以留言告訴我)
  6. 在sort_buffer中根據R值進行排序
  7. 排序完成以後,取出前三個結果的位置信息,到内存臨時表中取出word值,返回給客戶端。總掃描行數變為20003(MySQL8.0以後這裡是10003行)。

MySQL8.0下慢查詢日志如下圖,掃描行數為100003行:

mysql生成随機函數(MySQL随機函數RAND)2

臨時表隻能是内存表麼?

答案是NO。那什麼時候臨時表會使用内存,什麼時候又會使用磁盤呢?該選擇主要依賴于tmp_table_size參數的控制,默認是16M,如果臨時表的大小超過了tmp_table_size,那麼内存臨時表就會轉換為磁盤臨時表。

磁盤臨時表使用的默認引擎是InnoDB,由參數default_tmp_storage_engine控制。

set tmp_table_size=1024; set sort_buffer_size=32768; set max_length_for_sort_data=16; /* 打開 optimizer_trace,隻對本線程有效 */ SET optimizer_trace='enabled=on'; /* 執行語句 */ select word from words order by rand() limit 3; /* 查看 OPTIMIZER_TRACE 輸出 */ SELECT * FROM `information_schema`.`OPTIMIZER_TRACE`\G

mysql生成随機函數(MySQL随機函數RAND)3

在我們上圖的輸出中,我們可以看出排序算法使用了優先隊列排序算法,然後是全字段排序(也就是說不用回表)。

peak_memory_used代表排序時使用到的内存,按道理應該等于sort_buffer_size指定的值,之所以不等的原因是作者本人的MySQL是8.0.12版本。

MySQL8.0.12之前,MySQL優化器會為排序直接分配sort_buffer_size指定大小的内存,但從MySQL8.0.12開始,為排序分配内存是以增量的方式進行

,
Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
整體廚房石英石台面多少錢一米 石英石櫥櫃好還是大理石櫥櫃好
整體廚房石英石台面多少錢一米 石英石櫥櫃好還是大理石櫥櫃好
現在的廚房台面多種多樣,較為常見的台面種類有石英石和大理石,那你知道整體廚房石英石台面多少錢一米,石英石櫥櫃好還是大理石櫥櫃好呢?下面就讓我們一起來了解下石英石櫥櫃和大理石櫥櫃,希望可以幫助更多的人正确選擇廚房台面。整體廚房石英石台面多少錢一米1、整體廚房石英石台面多少錢一米,根據現在的市場價格來看...
2025-07-02
23年結婚紀念日是什麼婚
23年結婚紀念日是什麼婚
23年結婚紀念日是綠玉婚。綠色的玉石玲珑剔透,象征着婚姻中的雙方對彼此知根知底,十分熟悉,也象征着彼此陪伴的難能可貴。在結婚紀念日當天,夫妻雙方可以彼此贈送綠玉,來回憶當初戀愛的美好時光。1、綠玉婚23年結婚紀念日代表的是綠玉婚,用寶石代表婚姻的說法起源于法國,綠色的玉石玲珑剔透,質地堅硬,用來象征...
2025-07-02
如何選購窗簾
如何選購窗簾
如果你家空間足夠大,應該配置一款适宜的窗簾,更能顯示你生活的品位。如何選購窗簾呢?很多用戶不知道怎麼選購,在選購窗簾的時候一定要對窗簾的顔色做好選擇,下面小編為大家介紹如何選購窗簾。如何選購窗簾一、如何選購窗簾——不規則房間窗簾軌道設計善于在不規則房間内利用軌道異型窗在住宅中比較普遍,比如圓弧形的,...
2025-07-02
正月十一請紫姑的寓意  正月十一吃春餅可用功讀書
正月十一請紫姑的寓意  正月十一吃春餅可用功讀書
在每年新年之際,每一天都存在非常多的風俗宜忌值得大家來探究,能夠在其中讨到吉祥的喜頭對于來年的運勢是很有幫助的,那麼在風俗文化當中,正月十一有哪些必須要做的事情呢?請紫姑是什麼傳統儀式?存在的意義是什麼?正月十一請紫姑正月十一要請自古,最早記載“紫姑”的文獻是南朝宋人劉敬叔的《異苑》。大緻說紫姑是人...
2025-07-02
申請非物質文化遺産需要什麼條件
申請非物質文化遺産需要什麼條件
1、具有突出貢獻的曆史、文化和科學價值。2、具有展現廣大人民群衆文化創造力的典型性、代表性。3、具有在一定群體中世代傳承、活态存在的特點。4、具有鮮明特色,在當地有較大影響。申報者須提交以下資料:1、申請報告:對申報項目名稱、申報者、申報目的和意義進行簡要說明。2、項目申報書:對申報項目的曆史、現狀、價值和瀕危狀況等進行說明。3、保護計劃:對未來十年的保護目标、措施、步驟和管理機制等進行說明。4、
2025-07-02
Copyright 2023-2025 - www.tftnews.com All Rights Reserved