Problème :
Vous avez une table MySQL avec deux colonnes, min_value et max_value. Vous souhaitez récupérer une valeur aléatoire entre ces deux valeurs.
La fonction RAND() de MySQL ne fournit pas directement cette fonctionnalité. La solution la plus proche est RAND() * (max-min) min, mais elle produit un flottant, pas un entier. Pour obtenir un entier, vous auriez besoin d'une autre fonction comme ROUND() pour tronquer la partie décimale, mais ce n'est pas pratique.
Solution :
La méthode la plus efficace dans MySQL doit utiliser l'expression originale ROUND((RAND() * (max-min)) min). Il s'agit également de la meilleure approche dans d'autres langages de programmation, tels qu'ActionScript, JavaScript et Python.
Comparaison des performances entre PHP et MySQL :
Si vous n'êtes pas sûr Que ce soit pour générer la valeur aléatoire en PHP ou MySQL, tenez compte du nombre de lignes impliquées. Si l'ensemble de données est volumineux, il est plus efficace d'utiliser MySQL.
Pour démontrer la différence de performances, comparons deux scénarios avec 100 000 itérations :
Cependant, si vous récupérez des colonnes supplémentaires avec la valeur aléatoire, PHP devient plus efficace :
En conclusion, pour des performances optimales, utilisez MySQL si seule la valeur aléatoire est requise, et utilisez PHP si des colonnes supplémentaires doivent être renvoyées.
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!