如何修复 MySQL Server 8.0 中的 PASSWORD 函数问题:语法指南

Barbara Streisand
发布: 2024-10-31 07:13:02
原创
651 人浏览过

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

排查 MySQL Server 8.0 中的 PASSWORD 函数问题

尝试在 MySQL Server 版本 8.0.12 中执行 PASSWORD 函数时,某些情况可能会出现问题触发错误。本文旨在解决此类问题并提供可行的解决方案。

错误代码 1064

如果您遇到错误“Error Code: 1064. You have 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
登录后复制

以上是如何修复 MySQL Server 8.0 中的 PASSWORD 函数问题:语法指南的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板