Heim >Datenbank >MySQL-Tutorial >Wie kann ich MySQLs ORDER BY RAND() für eine schnellere Abfrageleistung optimieren?

Wie kann ich MySQLs ORDER BY RAND() für eine schnellere Abfrageleistung optimieren?

Barbara Streisand
Barbara StreisandOriginal
2024-12-13 10:06:18382Durchsuche

How Can I Optimize MySQL's ORDER BY RAND() for Faster Query Performance?

Optimierung der ORDER BY RAND()-Funktion von MySQL

Einführung

Die Verwendung der Die Funktion ORDER BY RAND() in MySQL kann zu einer langsamen Abfrageleistung führen, insbesondere in schlecht optimierten Tabellen. Dieser Artikel befasst sich mit effizienten Techniken zur Optimierung solcher Abfragen und bietet praktische Lösungen zur Lösung dieses Problems.

Optimierungstechniken

Eine effektive Lösung beinhaltet die Verwendung einer Unterabfrage in Kombination mit STRAIGHT_JOIN, wie unten gezeigt:

SELECT  *
FROM    (
        SELECT  @cnt := COUNT(*) + 1,
                @lim := 10
        FROM    t_random
        ) vars
STRAIGHT_JOIN
        (
        SELECT  r.*,
                @lim := @lim - 1
        FROM    t_random r
        WHERE   (@cnt := @cnt - 1)
                AND RAND(20090301) < @lim / @cnt
        ) i

Diese Methode hat sich aufgrund der Unmittelbarkeit als besonders effizient für MyISAM-Tabellen erwiesen Art der COUNT(*)-Operation. Für InnoDB-Tabellen bleibt es deutlich schneller als ORDER BY RAND().

In Fällen, in denen nur ein einzelner Zufallsdatensatz erforderlich ist, kann ein anderer Ansatz verwendet werden:

SELECT  aco.*
FROM    (
        SELECT  minid + FLOOR((maxid - minid) * RAND()) AS randid
        FROM    (
                SELECT  MAX(ac_id) AS maxid, MIN(ac_id) AS minid
                FROM    accomodation
                ) q
        ) q2
JOIN    accomodation aco
ON      aco.ac_id =
        COALESCE
        (
        (
        SELECT  accomodation.ac_id
        FROM    accomodation
        WHERE   ac_id > randid
                AND ac_status != 'draft'
                AND ac_images != 'b:0;'
                AND NOT EXISTS
                (
                SELECT  NULL
                FROM    accomodation_category
                WHERE   acat_id = ac_category
                        AND acat_slug = 'vendeglatohely'
                )
        ORDER BY
                ac_id
        LIMIT   1
        ),
        (
        SELECT  accomodation.ac_id
        FROM    accomodation
        WHERE   ac_status != 'draft'
                AND ac_images != 'b:0;'
                AND NOT EXISTS
                (
                SELECT  NULL
                FROM    accomodation_category
                WHERE   acat_id = ac_category
                        AND acat_slug = 'vendeglatohely'
                )
        ORDER BY
                ac_id
        LIMIT   1
        )
        )

Diese Methode geht von einer relativ gleichmäßigen Verteilung der ac_id-Werte aus.

Das obige ist der detaillierte Inhalt vonWie kann ich MySQLs ORDER BY RAND() für eine schnellere Abfrageleistung optimieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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