解決MySQL Server 8.0 中的PASSWORD 函數問題
嘗試在MySQL Server 版本8.0.12 中執行PASSWORD 函數時,某些情況可能會發生觸發錯誤。本文旨在解決此類問題並提供可行的解決方案。
錯誤代碼1064
如果您遇到錯誤“Error Code: 1064. You had an error in你的SQL 語法...”,它表明你的查詢語法存在問題。具體來說,MySQL Server 8.0 版中的 PASSWORD 函數語法已更改。
新語法
在 MySQL Server 8.0 中,PASSWORD 函數已被棄用並替換為不同的語法雜湊機制。為了保持相容性,您應該使用下列語法產生與先前版本中PASSWORD 函數產生的雜湊等效的雜湊:
CONCAT('*', UPPER(SHA1(UNHEX(SHA1('my_password')))))
範例
在提供的查詢中,「pwd = PASSWORD('2018')」表示「pwd」欄位與靜態密碼的比較。若要使用新語法擷取密碼為「2018」的用戶,您可以如下修改查詢:
SELECT * FROM users WHERE login = 'FABIO' AND pwd = CONCAT('*', UPPER(SHA1(UNHEX(SHA1('2018'))))) LIMIT 0, 50000
免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。
Copyright© 2022 湘ICP备2022001581号-3