Heim Datenbank MySQL-Tutorial 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%
方案三

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Unbedingt vor dem Kauf eines Systems lesen: Analyse der Vor- und Nachteile von Win11 und Win10 Unbedingt vor dem Kauf eines Systems lesen: Analyse der Vor- und Nachteile von Win11 und Win10 Mar 28, 2024 pm 01:33 PM

Im heutigen Informationszeitalter spielen Personalcomputer eine wichtige Rolle als unverzichtbares Werkzeug in unserem täglichen Leben. Als eine der Kernsoftware von Computern beeinflusst das Betriebssystem unser Nutzungserlebnis und unsere Arbeitseffizienz. Auf dem Markt hatte Microsofts Windows-Betriebssystem schon immer eine dominierende Stellung eingenommen, doch nun stehen die Menschen vor der Wahl zwischen dem neuesten Windows 11 und dem alten Windows 10. Normale Verbraucher achten bei der Auswahl eines Betriebssystems nicht nur auf die Versionsnummer, sondern verstehen auch deren Vor- und Nachteile.

Was sind die Vor- und Nachteile des Templatings? Was sind die Vor- und Nachteile des Templatings? May 08, 2024 pm 03:51 PM

Templating: Vor- und Nachteile Templating ist eine leistungsstarke Programmiertechnik, mit der Sie wiederverwendbare Codeblöcke erstellen können. Es bietet eine Reihe von Vorteilen, aber auch einige Nachteile. Vorteile: Wiederverwendbarkeit des Codes: Mit Templating können Sie gemeinsamen Code erstellen, der in Ihrer gesamten Anwendung wiederverwendet werden kann, wodurch Duplizierung und Wartungsaufwand reduziert werden. Konsistenz: Mithilfe von Vorlagen wird sichergestellt, dass Codeausschnitte an verschiedenen Stellen auf die gleiche Weise implementiert werden, wodurch die Konsistenz und Lesbarkeit des Codes verbessert wird. Wartbarkeit: Änderungen an einer Vorlage werden gleichzeitig im gesamten Code widergespiegelt, der sie verwendet, wodurch Wartung und Aktualisierungen vereinfacht werden. Effizienz: Templating spart Zeit und Aufwand, da Sie nicht immer wieder denselben Code schreiben müssen. Flexibilität: Mithilfe von Vorlagen können Sie konfigurierbare Codeblöcke erstellen, die problemlos an unterschiedliche Anwendungsanforderungen angepasst werden können. Mangel

Welche Vor- und Nachteile hat die Funktionsweise von Java-Servlets? Welche Vor- und Nachteile hat die Funktionsweise von Java-Servlets? Apr 16, 2024 pm 03:18 PM

JavaServlet ist eine Java-Klasse, die zum Erstellen dynamischer Webseiten verwendet wird und als Brücke zwischen Client und Server dient. Arbeitsprinzip: Anfragen empfangen, Servlet initialisieren, Anfragen verarbeiten, Antworten generieren und Servlet schließen. Vorteile: Portabel, skalierbar, sicher und einfach zu bedienen. Nachteile: Overhead, Kopplung und Zustandsverwaltung. Praktischer Fall: Erstellen Sie ein einfaches Servlet, um die Nachricht „Hallo, Servlet!“ anzuzeigen.

Vergleich der Vor- und Nachteile von PHP-Frameworks: Welches ist besser? Vergleich der Vor- und Nachteile von PHP-Frameworks: Welches ist besser? Jun 04, 2024 pm 03:36 PM

Die Wahl des PHP-Frameworks hängt von den Projektanforderungen und Entwicklerfähigkeiten ab: Laravel: reich an Funktionen und aktiver Community, weist jedoch eine steile Lernkurve und einen hohen Leistungsaufwand auf. CodeIgniter: Leicht und einfach zu erweitern, verfügt jedoch über eingeschränkte Funktionalität und weniger Dokumentation. Symfony: Modulare, starke Community, aber komplexe Leistungsprobleme. ZendFramework: für Unternehmen geeignet, stabil und zuverlässig, aber umfangreich und teuer in der Lizenzierung. Schlank: Mikro-Framework, schnell, aber mit eingeschränkter Funktionalität und einer steilen Lernkurve.

Vor- und Nachteile der Verwendung von Chinesisch bei der Benennung von Java-Variablen Vor- und Nachteile der Verwendung von Chinesisch bei der Benennung von Java-Variablen Feb 18, 2024 am 10:14 AM

Vor- und Nachteile der Verwendung von Chinesisch zur Benennung von Java-Variablen In der Java-Programmierung verwenden wir normalerweise Englisch, um Bezeichner wie Variablen, Methoden und Klassen zu benennen. Manchmal können wir jedoch auch die Verwendung von Chinesisch als Teil der Kennung in Betracht ziehen. In diesem Artikel werden die Vor- und Nachteile der Verwendung chinesischer benannter Java-Variablen untersucht und einige spezifische Codebeispiele aufgeführt. Vorteil 1: Verbessern Sie die Lesbarkeit des Codes. Durch die Verwendung chinesischer benannter Java-Variablen kann der Code leichter verständlich und lesbar gemacht werden. Schließlich versteht und erkennt unser Gehirn Chinesisch natürlicher und flüssiger als Englisch. Für Nicht-Englisch

Zusammenfassung des Golang-Compilers: Entdecken Sie die Vor- und Nachteile verschiedener Compiler Zusammenfassung des Golang-Compilers: Entdecken Sie die Vor- und Nachteile verschiedener Compiler Jan 19, 2024 am 10:44 AM

Mit der Entwicklung von Golang wurden immer mehr Compiler entwickelt. Bei der Auswahl eines Compilers müssen Entwickler viele Faktoren berücksichtigen, wie z. B. Zuverlässigkeit, Leistung, Benutzerfreundlichkeit usw. In diesem Artikel werden einige gängige Golang-Compiler zusammengefasst und ihre Vor- und Nachteile untersucht, um Entwicklern bei der Auswahl des für sie geeigneten Compilers zu helfen. Offizieller Go-Compiler Der offizielle Go-Compiler ist der Standard-Compiler von Golang und ein weithin anerkannter Compiler in der Golang-Community. Es hat die folgenden Vorteile: gute Stabilität, geringe Größe und Zusammenstellung

C-Sprache und Python: Analyse anwendbarer Szenarien sowie Vor- und Nachteile C-Sprache und Python: Analyse anwendbarer Szenarien sowie Vor- und Nachteile Mar 22, 2024 am 11:24 AM

C-Sprache und Python: Analyse anwendbarer Szenarien sowie Vor- und Nachteile Im Bereich der Computerprogrammierung sind C-Sprache und Python zwei sehr beliebte Programmiersprachen. Sie haben jeweils einzigartige Vor- und Nachteile und eignen sich für unterschiedliche Szenarien. In diesem Artikel wird eine eingehende Analyse der C-Sprache und Python durchgeführt und ihre anwendbaren Szenarien sowie Vor- und Nachteile erörtert. 1. Anwendbare Szenarien für die C-Sprache: Die C-Sprache ist eine prozessorientierte Programmiersprache mit hoher Effizienz und hervorragender Leistung. Sie eignet sich für die Entwicklung von Systemsoftware, Treibern und eingebetteten Systemen, die ein hohes Maß an Kontrolle und Effizienz erfordern.

Gründe für Vor- und Nachteile des Java-Frameworks Gründe für Vor- und Nachteile des Java-Frameworks Jun 03, 2024 pm 04:50 PM

Vor- und Nachteile des Java-Frameworks: Vorteile: Beschleunigte Entwicklung, verbesserte Codequalität, reichhaltiges Ökosystem, Code-Wiederverwendung, Nachteile: Leistungsaufwand, Komplexität und Lernkurve, mangelnde Flexibilität, Wartungsaufwand

See all articles