Résolution des écarts à virgule flottante dans les sélections MySQL
Lors de l'exécution d'une instruction SELECT avec une clause WHERE qui compare une valeur flottante à une constante, les utilisateurs peuvent rencontrer des résultats inattendus. Par exemple, la requête suivante ne renvoie aucune ligne :
<code class="sql">SELECT * FROM `table` WHERE `ident`='ident23' AND `price`='101.31';</code>
Cependant, la suppression de la condition de comparaison de prix donne la ligne correcte :
<code class="sql">SELECT * FROM `table`;</code>
Cet écart peut être attribué à la façon dont MySQL gère précision en virgule flottante. Bien que la valeur extraite de la base de données indique « 101,31 », elle peut différer légèrement de la constante réelle utilisée dans la clause WHERE en raison d'inexactitudes arithmétiques à virgule flottante.
Solution : conversion en DECIMAL
Pour résoudre ce problème, on peut convertir la colonne prix en type DECIMAL dans la clause WHERE :
<code class="sql">SELECT * FROM `table` WHERE CAST(price AS DECIMAL) = CAST(101.31 AS DECIMAL);</code>
Cela garantit que la valeur de la base de données et la constante sont représentées sous forme DECIMAL, éliminant tout problème de précision potentiel.
Solution alternative : changer le type de colonne
Comme alternative, envisagez de modifier directement le type de données de la colonne de prix en DECIMAL. DECIMAL offre une plus grande précision et une plus grande échelle lorsque vous travaillez avec des valeurs monétaires, éliminant ainsi le besoin de conversion dans les requêtes SELECT.
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!