>  기사  >  데이터 베이스  >  MySQL8.0/8.x에서 비밀번호를 잊어버린 경우 루트 비밀번호를 변경하는 방법

MySQL8.0/8.x에서 비밀번호를 잊어버린 경우 루트 비밀번호를 변경하는 방법

WBOY
WBOY앞으로
2023-06-03 21:01:062020검색

1. 원리 설명

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"这样的明文会导致密码错误登录不上。

原因是服务器在验证身份时会先将用户输入的明文转为密文与数据库中的密文作对比验证是否匹配,而直接在本应放密文的地方放入明文显然不会让它们匹配成功。

MySQL8.0/8.x에서 비밀번호를 잊어버린 경우 루트 비밀번호를 변경하는 방법

3,在网上近似的搜索结果“mysql修改密码”中,会使用alter user root@localhost identified by '12345'来修改密码,这句命令在“跳过授权表”时是使用不了的,唯有正常模式下可以使用

MySQL8.0/8.x에서 비밀번호를 잊어버린 경우 루트 비밀번호를 변경하는 방법

4,才有了这样的解决方法,先将authentication_string变为空,毕竟空值的明文密文都是空值,用空密码进入mysql正常模式后再使用alter将密码改掉即可。

MySQL8.0/8.x에서 비밀번호를 잊어버린 경우 루트 비밀번호를 변경하는 방법

二、解决步骤

1,停止mysql服务

net stop mysql

MySQL8.0/8.x에서 비밀번호를 잊어버린 경우 루트 비밀번호를 변경하는 방법

2,输入命令,进入“跳过授权表”模式

mysqld --console --skip-grant-tables --shared-memory

MySQL8.0/8.x에서 비밀번호를 잊어버린 경우 루트 비밀번호를 변경하는 방법

3,上一个cmd窗口先放一旁,另开个管理员cmd窗口,输入mysql进入mysql服务

MySQL8.0/8.x에서 비밀번호를 잊어버린 경우 루트 비밀번호를 변경하는 방법

4,输入use mysql进入mysql数据库,再将authentication_string改为空

USE mysql;
UPDATE user SET authentication_string="" WHERE user="root";

MySQL8.0/8.x에서 비밀번호를 잊어버린 경우 루트 비밀번호를 변경하는 방법

5,刷新权限,退出

FLUSH privileges;
exit;

MySQL8.0/8.x에서 비밀번호를 잊어버린 경우 루트 비밀번호를 변경하는 방법

6,第一个cmd窗口中,使用ctrl+c

2. 인터넷에서 찾은 "mysql 비밀번호 찾기" 해결 방법 중 대부분은 UPDATE user SET 인증_string="12345" WHERE user="root";를 사용하여 비밀번호를 직접 변경합니다. to 12345 는 사실 잘못된 사용법입니다.authentication_string은 암호문을 저장하고 있습니다. "12345"와 같은 일반 텍스트로 직접 변경하면 비밀번호가 올바르지 않아 로그인이 불가능합니다.

MySQL8.0/8.x에서 비밀번호를 잊어버린 경우 루트 비밀번호를 변경하는 방법그 이유는 신원을 확인할 때 서버는 먼저 사용자가 입력한 평문을 암호문으로 변환하고 이를 데이터베이스의 암호문과 비교하여 일치 여부를 확인하기 때문입니다. 암호문이 있어야 할 곳에 직접 평문을 넣으면 당연히 됩니다. 매치가 성공하지 못하게 하세요.

MySQL8.0에서 비밀번호를 잊어버린 경우 루트 비밀번호를 변경하는 방법/ 8.x

3. 유사한 온라인 검색 결과 "mysql 비밀번호 변경"에서 '12345'로 식별된 Alter user root@localhost를 사용하여 비밀번호를 변경합니다. 이 명령은 "스킵 인증 테이블"에서 사용할 수 없으며 일반 모드에서만 사용할 수 있습니다MySQL8.0/8.x에서 비밀번호를 잊어버린 경우 루트 비밀번호를 변경하는 방법

MySQL8.0 /8.x 비밀번호를 잊은 경우 루트 비밀번호를 변경하는 방법은 무엇입니까?

4 그런 해결 방법이 있습니다. 먼저 인증 문자열을 비워두세요. 빈 값은 모두 빈 값입니다. 모드에 진입한 후 비밀번호를 변경하려면 mysql을 입력하는 것이 정상입니다.

MySQL8.0/8.x에서 비밀번호를 잊어버린 경우 루트 비밀번호를 변경하는 방법MySQL8.0에서 비밀번호를 잊어버린 경우 루트 비밀번호를 변경하는 방법/ 8.x

🎜2. 해결 단계🎜🎜1. mysql 서비스를 중지합니다🎜
net start mysql
🎜MySQL8.0/8.x 비밀번호를 잊어버린 경우 루트 비밀번호를 변경하는 방법🎜🎜2. "인증 양식 건너뛰기" 모드로 들어가는 명령을 입력하세요🎜
mysql -uroot -p
🎜MySQL8.0/8.x에서 비밀번호를 잊어버린 경우 루트 비밀번호를 변경하는 방법🎜 🎜3. 이전 cmd 창을 옆으로 치우고 다른 관리자 cmd 창을 엽니다. mysql을 입력하여 mysql 서비스에 들어갑니다🎜🎜MySQL8.0/ 8.x 비밀번호를 잊어버린 경우 루트 비밀번호를 변경하는 방법🎜🎜4. use mysql을 입력하여 mysql 데이터베이스를 입력한 다음 인증_문자열을 공백으로 변경하세요🎜
alter user root@localhost identified by '12345'
FLUSH privileges;
exit
🎜변경 방법 MySQL8.0/8.x가 비밀번호를 잊어버린 경우 루트 비밀번호🎜🎜5, 권한 새로 고침, 종료🎜rrreee🎜MySQL8.0/8.x에서 비밀번호를 잊어버린 경우 루트 비밀번호를 변경하는 방법🎜🎜6, 첫 번째 cmd 창에서 ctrl+c를 사용하세요. > "인증 테이블 건너뛰기" 모드를 종료하려면 mysql 서비스 🎜rrreee🎜🎜🎜🎜7을 시작하고 빈 비밀번호를 사용하여 로그인한 다음 alter 문을 사용하여 비밀번호를 업데이트하고 권한을 새로 고치고 🎜rrreeerrreee🎜🎜를 종료하세요. 🎜🎜8, 비밀번호로 로그인 시도, 성공했습니다. 🎜🎜🎜🎜

위 내용은 MySQL8.0/8.x에서 비밀번호를 잊어버린 경우 루트 비밀번호를 변경하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 yisu.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제