Heim >Datenbank >MySQL-Tutorial >So beheben Sie Probleme mit der PASSWORD-Funktion in MySQL Server 8.0: Ein Syntax-Leitfaden

So beheben Sie Probleme mit der PASSWORD-Funktion in MySQL Server 8.0: Ein Syntax-Leitfaden

Barbara Streisand
Barbara StreisandOriginal
2024-10-31 07:13:02688Durchsuche

How to Fix PASSWORD Function Issues in MySQL Server 8.0: A Syntax Guide

Beheben von Problemen mit der PASSWORD-Funktion in MySQL Server 8.0

Beim Versuch, die PASSWORD-Funktion in MySQL Server Version 8.0.12 auszuführen, können bestimmte Szenarien auftreten einen Fehler auslösen. Ziel dieses Artikels ist es, solche Probleme anzugehen und eine praktikable Lösung anzubieten.

Fehlercode 1064

Wenn Sie auf den Fehler „Fehlercode: 1064. Sie haben einen Fehler in Ihre SQL-Syntax ...“, weist dies auf ein Problem mit der Syntax Ihrer Abfrage hin. Insbesondere hat sich die Syntax der PASSWORD-Funktion in MySQL Server Version 8.0 geändert.

Neue Syntax

Mit MySQL Server 8.0 wurde die PASSWORD-Funktion veraltet und durch eine andere ersetzt Hashing-Mechanismus. Um die Kompatibilität aufrechtzuerhalten, sollten Sie die folgende Syntax verwenden, um einen Hash zu generieren, der dem entspricht, der von der PASSWORD-Funktion in früheren Versionen erzeugt wurde:

CONCAT('*', UPPER(SHA1(UNHEX(SHA1('my_password')))))

Beispiel

In Die bereitgestellte Abfrage „pwd = PASSWORD('2018')“ stellt den Vergleich der Spalte „pwd“ mit einem statischen Passwort dar. Um Benutzer mit dem Passwort „2018“ mithilfe der neuen Syntax abzurufen, können Sie die Abfrage wie folgt ändern:

SELECT * 
FROM users 
WHERE login = 'FABIO' 
  AND pwd = CONCAT('*', UPPER(SHA1(UNHEX(SHA1('2018')))))
LIMIT 0, 50000

Das obige ist der detaillierte Inhalt vonSo beheben Sie Probleme mit der PASSWORD-Funktion in MySQL Server 8.0: Ein Syntax-Leitfaden. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn