1. authentication_string
이는 Mysql8.0에서 새롭게 수정된 사항으로, 이전 버전에서는 패스워드() 함수를 사용했습니다. authentication_string
这是Mysql8.0新做出的修改,在旧版本中使用的是password()函数。
2,在网上找到的“mysql忘记密码”的解决方案中,大多会使用UPDATE user SET authentication_string="12345" WHERE user="root";
来直接将密码改成12345,实际上这是错误的用法,authentication_string中存储的是密文,如果直接改为"12345"这样的明文会导致密码错误登录不上。
原因是服务器在验证身份时会先将用户输入的明文转为密文与数据库中的密文作对比验证是否匹配,而直接在本应放密文的地方放入明文显然不会让它们匹配成功。
3,在网上近似的搜索结果“mysql修改密码”中,会使用alter user root@localhost identified by '12345'
来修改密码,这句命令在“跳过授权表”时是使用不了的,唯有正常模式下可以使用
4,才有了这样的解决方法,先将authentication_string变为空,毕竟空值的明文密文都是空值,用空密码进入mysql正常模式后再使用alter将密码改掉即可。
1,停止mysql服务
net stop mysql
2,输入命令,进入“跳过授权表”模式
mysqld --console --skip-grant-tables --shared-memory
3,上一个cmd窗口先放一旁,另开个管理员cmd窗口,输入mysql
进入mysql服务
4,输入use mysql
进入mysql数据库,再将authentication_string改为空
USE mysql; UPDATE user SET authentication_string="" WHERE user="root";
5,刷新权限,退出
FLUSH privileges; exit;
6,第一个cmd窗口中,使用ctrl+c
UPDATE user SET 인증_string="12345" WHERE user="root";
를 사용하여 비밀번호를 직접 변경합니다. to 12345 는 사실 잘못된 사용법입니다.authentication_string은 암호문을 저장하고 있습니다. "12345"와 같은 일반 텍스트로 직접 변경하면 비밀번호가 올바르지 않아 로그인이 불가능합니다. 그 이유는 신원을 확인할 때 서버는 먼저 사용자가 입력한 평문을 암호문으로 변환하고 이를 데이터베이스의 암호문과 비교하여 일치 여부를 확인하기 때문입니다. 암호문이 있어야 할 곳에 직접 평문을 넣으면 당연히 됩니다. 매치가 성공하지 못하게 하세요.
3. 유사한 온라인 검색 결과 "mysql 비밀번호 변경"에서 '12345'로 식별된 Alter user root@localhost
를 사용하여 비밀번호를 변경합니다. 이 명령은 "스킵 인증 테이블"에서 사용할 수 없으며 일반 모드에서만 사용할 수 있습니다
🎜2. 해결 단계🎜🎜1. mysql 서비스를 중지합니다🎜
net start mysql🎜🎜🎜2. "인증 양식 건너뛰기" 모드로 들어가는 명령을 입력하세요🎜
mysql -uroot -p🎜🎜 🎜3. 이전 cmd 창을 옆으로 치우고 다른 관리자 cmd 창을 엽니다.
mysql
을 입력하여 mysql 서비스에 들어갑니다🎜🎜🎜🎜4. use mysql
을 입력하여 mysql 데이터베이스를 입력한 다음 인증_문자열을 공백으로 변경하세요🎜alter user root@localhost identified by '12345' FLUSH privileges; exit🎜🎜🎜5, 권한 새로 고침, 종료🎜rrreee🎜🎜🎜6, 첫 번째 cmd 창에서
ctrl+c
를 사용하세요. > "인증 테이블 건너뛰기" 모드를 종료하려면 mysql 서비스 🎜rrreee🎜🎜🎜🎜7을 시작하고 빈 비밀번호를 사용하여 로그인한 다음 alter 문을 사용하여 비밀번호를 업데이트하고 권한을 새로 고치고 🎜rrreeerrreee🎜🎜를 종료하세요. 🎜🎜8, 비밀번호로 로그인 시도, 성공했습니다. 🎜🎜🎜🎜위 내용은 MySQL8.0/8.x에서 비밀번호를 잊어버린 경우 루트 비밀번호를 변경하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!