MySQL-MySQL-String-to-Number-Konvertierungsrätsel: Warum „String“ = 0 „True“ zurückgibt
Beim Vergleich einer String-Spalte mit 0, a Es kommt zu einem überraschenden Ergebnis: Es wird als wahr ausgewertet. Dieses unerwartete Verhalten ist auf den impliziten Typkonvertierungsmechanismus von MySQL zurückzuführen.
MySQL wandelt Zeichenfolgen basierend auf den folgenden Regeln automatisch in Zahlen um:
Im Fall von 'string' = 0 wird die Zeichenfolge als 0 ausgewertet, da sie nicht mit einer Zahl beginnt. Diese Konvertierung führt dazu, dass der Vergleich zu '0' = 0 wird. was wahr ist.
Beim Vergleich der Zeichenfolge mit einer Zahl ungleich Null oder einer Zeichenfolge erfolgt jedoch keine Konvertierung. Als Ergebnis wird „string“ = -12 oder „string“ = „0“ erwartungsgemäß als „false“ ausgewertet.
Um dieses Standardverhalten zu überschreiben, können Sie mithilfe des Operators eine Konvertierung in einen bestimmten Datentyp erzwingen. Beispielsweise wandelt „0string“ 0 die Zeichenfolge „0string“ in eine Zahl um, sodass der Vergleich „0“ = „0“ gültig ist.
Dieser Konvertierungsmechanismus kann auch verwendet werden, um arithmetische Operationen an Zeichenfolgen durchzuführen, die Zahlen enthalten . Beispielsweise wandelt „1abc“ „2ef“ die Zeichenfolgen in Zahlen um und summiert sie, was zu 3 führt.
Das Verständnis dieses Typkonvertierungsverhaltens ist entscheidend, um unerwartete Ergebnisse bei MySQL-Abfragen zu vermeiden. Indem Sie den Operator nutzen, um Konvertierungen explizit zu steuern, können Sie sicherstellen, dass Ihre Vergleiche und Berechnungen korrekt sind.
Das obige ist der detaillierte Inhalt vonWarum gibt \'String\' = 0 in MySQL True zurück?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!