Pagination PHP MySQL avec ordre aléatoire
Lors de la mise en œuvre d'une fonctionnalité de recherche avec pagination sur un site Web, il est crucial de résoudre les problèmes liés à l'ordre aléatoire classement des résultats. Cet article propose des solutions aux défis suivants :
-
Exclusion des résultats précédemment vus sur les pages suivantes :
Pour éviter que les résultats déjà consultés ne réapparaissent, une solution efficace en termes de mémoire consiste à utilisez une technique appelée pagination avec liste d'exclusion. Il s'agit de stocker les identifiants des résultats affichés dans une session ou une base de données et de les exclure des requêtes ultérieures.
-
Assurer différents ensembles de résultats sur la première page :
Pour garantir un affichage unique ensemble de résultats sur la première page, vous pouvez utiliser la fonction RAND() avec une valeur de départ constante. En modifiant cette valeur de départ après chaque visite, vous pouvez garantir une nouvelle commande sans compromettre le tri aléatoire.
-
Mise en œuvre pratique de la valeur de départ :
Dans MySQL, vous pouvez utiliser le RAND( SEED), où SEED est un entier spécifié par l’utilisateur. En définissant la valeur de départ sur une valeur différente chaque fois que l'utilisateur visite la première page, vous pouvez obtenir un classement aléatoire mais distinct.
Exemple :
<code class="php"><?php
session_start();
// Generate a unique seed value for the first page
if (!isset($_SESSION['seed'])) {
$_SESSION['seed'] = rand(1, 1000);
}
// Exclude previously seen results
$excludedIds = array();
if (isset($_SESSION['seenResults'])) {
$excludedIds = $_SESSION['seenResults'];
}
// Query with random ordering and exclusion
$query = "SELECT * FROM table WHERE id NOT IN ('" . implode("', '", $excludedIds) . "') ORDER BY RAND(" . $_SESSION['seed'] . ") LIMIT 10";</code>
Copier après la connexion
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!