После установки базы данных, поскольку я случайно закрыл окно установки напрямую или долгое время не входил в систему как пользователь root, я забыл пароль root. В это время мне нужно сбросить пароль root MySQL. Конечно, самый простой способ — удалить каталог данных базы данных, а затем переустановить базу данных. Но во многих случаях нам необходимо сохранить данные в каталоге данных, поэтому нам нужно узнать, как сбросить пароль root.
Мы знаем, что если вы знаете пароль root, вы можете использовать команду «ALTER USER ‘root’@’localhost’ IDENTIFIED BY ‘newpassword’;», чтобы изменить пароль пользователя root, как показано ниже:
Эта строка инструкции достаточна для сброса пароля root. Никаких других операций не требуется. Это очень просто. но,Если вы забыли свой пароль root,Как его сбросить? По описанию в официальной документации,Есть два способа изменить пароль в системе Windows.,Пожалуйста, обратитесь к официальной документации:https://dev.mysql.com/doc/refman/8.0/en/resetting-permissions.html Вариант 1: выполнить файл инициализации Шаг 1:Войдите в систему, используя учетную запись с правами администратора.; Шаг 2:останавливатьсяMySQLуслуги,независимо от того, какой метод,Это должно прекратиться,Как показано ниже:
Шаг 3:создать файлmysql-init.txt,Есть инструкция по смене пароля.“ALTER USER ‘root’@’localhost’ IDENTIFIED BY 'Новый пароль';», а затем сохраните файл, как показано на рисунке:
Шаг 4:В интерфейсе терминала,Введите каталог bin установки MySQL:
Шаг 5:существоватьbinв каталоге,Выполнить mysqld,И укажите только что созданный mysql-ini.txt в качестве файла инициализации.,Команда использования“mysqld –defaults-file=”D:\Programs\MySQL\MySQL-8.0.12-winx64\my.ini” –init-file="D:\Programs\MySQL\mysql-ini.txt"”, где –defaults-file указывает файл конфигурации, а –init-file указывает файл для выполнения инициализации, как показано на следующем рисунке:
После нажатия клавиши Enter не закрывайте терминал. Вам нужно открыть другой терминал, чтобы подтвердить успешность смены пароля:
Очевидно, вход прошел успешно и пароль был изменен правильно! Конечно, если вы действительно закроете терминал, вы также можете использовать команду «net start MySQL» для запуска MySQL, а затем проверить:
Шаг 6:удалить Созданныйmysql-ini.txtдокумент,конечно,Это нормально, не удаляйте!
Решение 2. Сбросьте пароль root, пропустив проверку при входе в систему. Шаг 1:Сначала закрытьMySQLСлужить,Затем используйте элемент конфигурации «--skip-grant-tables».,Перезапустите службу MySQL, пропуская проверку разрешения:
Здесь используется команда «mysqld –shared-memory --skip-grant-tables», если это просто «mysqld --skip-grant-tables» приведет к сбою запуска mysqld с сообщением «TCP/IP, –shared-memory, or –named-pipe should be configured on NT Ошибка ОС». После тестирования только добавление «--shared-memory» может запуститься и получить доступ к базе данных. Шаг 2:существовать Открыть терминал,Используйте беспарольный метод для входа в базу данных, просто запустите MySQL напрямую:
Шаг 3:Сначала обновите команду выполнения“FLUSH ПРИВИЛЕГИИ;", обновить разрешения:
Затем выполните команду «ALTER USER 'root'@'localhost' IDENTIFIED BY 'new_psd_123';», чтобы обновить пароль: «new_psd_123» — это новый установленный пароль:
После завершения настройки запустите службу MySQL в обычном режиме и используйте имя пользователя и пароль, чтобы проверить успешность настройки!
Заявление об авторских правах: Содержание этой статьи добровольно предоставлено пользователями Интернета, а мнения, выраженные в этой статье, представляют собой только точку зрения автора. Этот сайт предоставляет только услуги по хранению информации, не имеет никаких прав собственности и не принимает на себя соответствующие юридические обязательства. Если вы обнаружите на этом сайте какое-либо подозрительное нарушение авторских прав/незаконный контент, отправьте электронное письмо, чтобы сообщить. После проверки этот сайт будет немедленно удален.
Издатель: Лидер стека программистов полного стека, укажите источник для перепечатки: https://javaforall.cn/184120.html Исходная ссылка: https://javaforall.cn