Probleme beim Float-Vergleich in MySQL-SELECT-Abfragen lösen
Bei MySQL-SELECT-Abfragen können beim Vergleich von Float-Werten Genauigkeitsprobleme auftreten. Um dieses Problem zu beheben, untersuchen wir die folgende Frage:
Frage:
Warum schlägt eine SELECT-Abfrage mit einem Float-Gleichheitsvergleich fehl, während das Entfernen des Vergleichs das Richtige zurückgibt Reihe? Wie können wir die Gleitkommazahl vor der Operation in zwei Ziffern umwandeln, um eine erfolgreiche Übereinstimmung zu erzielen?
Antwort:
Das Problem ergibt sich aus der in MySQL inhärenten Gleitkommagenauigkeit. Um dieses Problem zu lösen, können wir die Float-Spalte in einen Dezimaltyp umwandeln, der die Genauigkeit auf eine bestimmte Anzahl von Stellen gewährleistet.
Lösung:
Die folgende Abfrage stimmt erfolgreich überein den Gleitkommawert, indem Sie ihn in eine Dezimalzahl umwandeln:
SELECT * FROM `table` WHERE CAST(`price` AS DECIMAL) = CAST(101.31 AS DECIMAL);
Alternative Lösung:
Alternativ können Sie erwägen, die Preisspalte in DEZIMAL zu ändern, was besser geeignet ist für den Umgang mit Geldwerten und bietet eine bessere Präzisionskontrolle.
Das obige ist der detaillierte Inhalt vonWarum schlägt meine MySQL-SELECT-Abfrage beim Vergleich von Floats fehl, funktioniert aber, wenn ich den Vergleich entferne?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!