Table of Contents
1. mysql忘记密码
2. mysql无法登录
3. 执行grant时出现Access denied for user 'root'@'localhost' to database 'database'
Home Database Mysql Tutorial mysql常见问题_MySQL

mysql常见问题_MySQL

Jun 01, 2016 pm 01:12 PM

1. mysql忘记密码

vim /etc/my.conf 文件在mysqld下添加skip-grant-tables,表示mysql在登录的时候不检查权限。登录mysql。直接运行mysql
> use mysql;> update user set Password=password('root') where User='root'> flush privileges;> quit;
Copy after login
User表存储的是mysql的用户的权限和密码,mysql密码都是经过加密后存储的,所以我们的密码需要用password函数对其进行加密。删掉第一步添加的skip-grant-tables;重启mysql. service mysqld restart

2. mysql无法登录

首先检查mysql服务器是否开启,service mysqld status.如果开启了,但是仍然登录不进去,如登录账户是bob, 可以用root账户登录mysql.user表,查看bob账户的Host是否正确,如果在登录mysql服务器没有明确指定Host,默认是localhost,有时表中有127.0.0.1,但是没有localhost,这个时候尝试下mysql -h127.0.0.1 -ubob -p如果能够登录,那就每次登录的时候直接制定host登录,或者修改mysql.user表,添加root@localhost.
> use mysql;> insert into user(Host,User,Password) values('localhost','bob',password('1234'));> grant all on *.*  to 'bob'@'localhost'
Copy after login
最后一句是赋予权限的意思,赋予bob所有的权限,其中all可以换成[update|delete|insert|create...]等权限,*.*表示任意数据库的任意表,用户可以自己根据需要筛选。最后是赋予权限给哪个用户。如果创建用户后执行mysql -u bob -p仍然无法登录, Access denied for user 'bob'@'localhost' (using password: YES),这时需要检查下是否有''@localhost账户存在,如果有执行
DROP USER ''@'localhost';
Copy after login
由于mysql如果匹配到多个账户时,有特定的顺序the most-specific Host values first,详细见http://stackoverflow.com/questions/10299148/mysql-error-1045-28000-access-denied-for-user-billlocalhost-using-passw

3. 执行grant时出现Access denied for user 'root'@'localhost' to database 'database'

root@localhost没有访问database的权限。我们执行
SELECT * FROM mysql.user WHERE User='root' and Host="localhost" /G
Copy after login
/G表示以键值对形式返回,这样看起来更方面,其中我们会发现
 Grant_priv: N
Copy after login
表示账户没有grant权限,所以我们就赋予grant权限给它。
> update user set Grant_priv='Y' where User='root' and Host='localhost';> flush privileges;
Copy after login
重新登录mysql。笔者直接flush privilege后执行grant命令,出错,但是重新登录后成功了。
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot Article Tags

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Reduce the use of MySQL memory in Docker Reduce the use of MySQL memory in Docker Mar 04, 2025 pm 03:52 PM

Reduce the use of MySQL memory in Docker

How do you alter a table in MySQL using the ALTER TABLE statement? How do you alter a table in MySQL using the ALTER TABLE statement? Mar 19, 2025 pm 03:51 PM

How do you alter a table in MySQL using the ALTER TABLE statement?

How to solve the problem of mysql cannot open shared library How to solve the problem of mysql cannot open shared library Mar 04, 2025 pm 04:01 PM

How to solve the problem of mysql cannot open shared library

What is SQLite? Comprehensive overview What is SQLite? Comprehensive overview Mar 04, 2025 pm 03:55 PM

What is SQLite? Comprehensive overview

Run MySQl in Linux (with/without podman container with phpmyadmin) Run MySQl in Linux (with/without podman container with phpmyadmin) Mar 04, 2025 pm 03:54 PM

Run MySQl in Linux (with/without podman container with phpmyadmin)

Running multiple MySQL versions on MacOS: A step-by-step guide Running multiple MySQL versions on MacOS: A step-by-step guide Mar 04, 2025 pm 03:49 PM

Running multiple MySQL versions on MacOS: A step-by-step guide

What are some popular MySQL GUI tools (e.g., MySQL Workbench, phpMyAdmin)? What are some popular MySQL GUI tools (e.g., MySQL Workbench, phpMyAdmin)? Mar 21, 2025 pm 06:28 PM

What are some popular MySQL GUI tools (e.g., MySQL Workbench, phpMyAdmin)?

How do I secure MySQL against common vulnerabilities (SQL injection, brute-force attacks)? How do I secure MySQL against common vulnerabilities (SQL injection, brute-force attacks)? Mar 18, 2025 pm 12:00 PM

How do I secure MySQL against common vulnerabilities (SQL injection, brute-force attacks)?

See all articles