首頁 資料庫 mysql教程 MySQL查询随机数据的4种方法和性能对比_MySQL

MySQL查询随机数据的4种方法和性能对比_MySQL

Jun 01, 2016 pm 01:17 PM
優缺點

下面从以下四种方案分析各自的优缺点。
方案一:
SELECT * FROM `table` ORDER BY RAND() LIMIT 0,1;
这种方法的问题就是非常慢。原因是因为MySQL会创建一张零时表来保存所有的结果集,然后给每个结果一个随机索引,然后再排序并返回。
有几个方法可以让它快起来。
基本思想就是先获取一个随机数,然后使用这个随机数来获取指定的行。
由于所有的行都有一个唯一的id,我们将只取最小和最大id之间的随机数,然后获取id为这个数行。为了让这个方法当id不连续时也能有效,我们在最终的查询里使用”>=”代替”=”。
为了获取整张表的最小和最大id,我们使用MAX()和MIN()两个聚合函数。这两个方法会返回指定组里的最大和最小值。在这里这个组就是我们表里的所有id字段值。
方案二:
$range_result = mysql_query( " SELECT MAX(`id`) AS max_id , MIN(`id`) AS min_id FROM `table` ");
$range_row = mysql_fetch_object( $range_result );
$random = mt_rand( $range_row->min_id , $range_row->max_id );
$result = mysql_query( " SELECT * FROM `table` WHERE `id` >= $random LIMIT 0,1 ");
就像我们刚才提到的,这个方法会用唯一的id值限制表的每一行。那么,如果不是这样情况怎么办?
下面这个方案是使用了MySQL的LIMIT子句。LIMIT接收两个参数值。第一个参数指定了返回结果第一行的偏移量,第二个参数指定了返回结果的最大行数。偏移量指定第一行是0而不是1。
为了计算第一行的偏移量,我们使用MySQL的RAND()方法从0到1之间生成一个随机数。然后我们把这个数字跟我们用COUNT()方法获取倒的表记录数相乘。由于LIMIT的参数必须是int型而不能是float,我们使用FLOOR()来处理结果。FLOOR()会计算小于表达式的最大值。最终的代码就是这样:
方案三:
$offset_result = mysql_query( " SELECT FLOOR(RAND() * COUNT(*)) AS `offset` FROM `table` ");
$offset_row = mysql_fetch_object( $offset_result );
$offset = $offset_row->offset;
$result = mysql_query( " SELECT * FROM `table` LIMIT $offset, 1 " );
在MySQL 4.1以后我们可以使用子子查询合并上面两个方法:
方案四:
SELECT * FROM `table` WHERE id >= (SELECT FLOOR( MAX(id) * RAND()) FROM `table` ) ORDER BY id LIMIT 1;
这个方案跟方案二有同样的弱点,只对有唯一id值的表有效。
记住我们最初寻找选择随机行的替代方法的原因,速度!所以,这些方案的在执行时间上的比较会怎么样?我不会指出硬件和软件配置或者给出具体的数字。大概的结果是这样的:
最慢的是解决方案一(我们假定它用了100%的时间)。
方案二用了79%
方案三

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

選購系統前必看:Win11和Win10優缺點分析 選購系統前必看:Win11和Win10優缺點分析 Mar 28, 2024 pm 01:33 PM

在當今資訊時代,個人電腦作為我們日常生活中不可或缺的工具,扮演著重要的角色。作業系統作為電腦的核心軟體之一,更是影響我們的使用體驗以及工作效率。在市場上,微軟公司的Windows作業系統一直佔據主導地位,而現在人們面臨的選擇則是最新的Windows11和舊有的Windows10。對於一般消費者來說,在選擇作業系統時不只是看版本號,更要了解其優缺點。

模板化的優點和缺點有哪些? 模板化的優點和缺點有哪些? May 08, 2024 pm 03:51 PM

模板化:優點與缺點模板化是一種強大的程式設計技術,可讓您建立可重複使用的程式碼區塊。它提供了一系列優點,但也存在一些缺點。優點:程式碼重用性:模板化可讓您建立通用程式碼,可在整個應用程式中重複使用,從而減少重複和維護工作。一致性:模板化確保程式碼段在不同位置以相同的方式實現,從而提高程式碼一致性和可讀性。可維護性:對範本的變更會同時反映在所有使用它的程式碼中,簡化了維護和更新流程。效率:模板化可以節省時間和精力,因為您不必重複編寫相同的程式碼。靈活性:模板化可讓您建立可設定的程式碼區塊,可輕鬆適應不同的應用程式需求。缺點

Java Servlet的工作原理有什麼優缺點? Java Servlet的工作原理有什麼優缺點? Apr 16, 2024 pm 03:18 PM

JavaServlet是一種Java類,用於建立動態網頁,作為客戶端和伺服器的橋樑。工作原理:接收請求、初始化Servlet、處理請求、產生回應和關閉Servlet。優點:可移植、可擴展、安全且易於使用。缺點:開銷、耦合和狀態管理。實戰案例:建立一個簡單的Servlet來顯示"Hello,Servlet!"訊息。

命名Java變數時使用中文的優點和缺點 命名Java變數時使用中文的優點和缺點 Feb 18, 2024 am 10:14 AM

使用中文命名Java變數的優缺點在Java程式設計中,我們通常使用英文來命名變數、方法和類別等識別碼。然而,有時候我們也可以考慮使用中文作為識別符的一部分。本文將探討使用中文命名Java變數的優缺點,並給出一些具體的程式碼範例。優點一:提高程式碼可讀性使用中文命名Java變數可以讓程式碼更容易理解和閱讀。畢竟,我們的大腦對於中文的理解和辨識要比英文更自然、更流暢。對於非英

PHP框架的優缺點比較:選哪個好? PHP框架的優缺點比較:選哪個好? Jun 04, 2024 pm 03:36 PM

PHP框架的選擇取決於專案需求和開發者技能:Laravel:功能豐富,社群活躍,但學習曲線陡峭,效能開銷高。 CodeIgniter:輕量級,易於擴展,但功能有限,文件較少。 Symfony:模組化,社群強大,但複雜,效能問題。 ZendFramework:企業級,穩定可靠,但笨重,許可昂貴。 Slim:微框架,速度快,但功能有限,學習曲線陡峭。

Golang編譯器彙總:探究各類編譯器優缺點 Golang編譯器彙總:探究各類編譯器優缺點 Jan 19, 2024 am 10:44 AM

隨著Golang的發展,越來越多的編譯器被開發出來。在選擇一款編譯器時,開發人員需要考慮許多因素,例如可靠性、效能、易用性等。本篇文章將彙整一些常見的Golang編譯器,並探討它們的優缺點,幫助開發者更好地選擇適合自己的編譯器。 Go官方編譯器Go官方編譯器是Golang的預設編譯器,也是Golang社群中廣受認可的編譯器。它具有以下優點:穩定性好體積小編譯

固態硬碟與機械硬碟的比較 固態硬碟與機械硬碟的比較 Feb 26, 2024 pm 06:21 PM

固態硬碟與機械硬碟的優缺點近年來,固態硬碟(SSD)逐漸走入大眾視野,並在個人電腦、伺服器等領域廣泛應用。相較之下,機械硬碟(HDD)作為傳統儲存設備也在可靠性和性價比方面有著優勢。本文將就固態硬碟和機械硬碟的優缺點進行比較分析,幫助讀者更好地選擇適合自己需求的儲存設備。首先,固態硬碟在讀寫速度上有明顯優勢。由於SSD採用快閃儲存存介質,讀寫速度較快,

C語言與Python:適用情境及優缺點分析 C語言與Python:適用情境及優缺點分析 Mar 22, 2024 am 11:24 AM

C語言與Python:適用情境及優缺點分析在電腦程式設計領域,C語言與Python是兩種非常流行的程式語言,它們各自有著獨特的優點和劣勢,適用於不同的場景。本文將對C語言與Python進行深入分析,探討它們的適用情境以及優缺點。一、C語言適用場景:C語言是一種以過程為導向的程式語言,具有高效性和優秀的效能,適合開發需要高度控制和效率的系統軟體、驅動程式和嵌入式系統

See all articles