解决 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