MySQL登录时出现x。。
场景⼀:调试web程序访问数据库的时候出现
场景⼆:MySQL登陆的时候,区分本地localhost登陆,以及远程登陆。即使本地能够登陆,如果不授权也⽆法远程登陆
分析原因:(区分)当本地出现这样的情况,就是密码错误,到正确的密码或者修改密码;当远程登陆的时候,⾸先确定登陆密码是否正确,第⼆确定是否远程授权。针对以上两种情况,给出解决⽅案。
情况⼀解决⽅案:修改本地数据库密码
⽅法1:⽤SET PASSWORD命令
⾸先登录MySQL。
格式:mysql> set password for ⽤户名@localhost = password('新密码');
例⼦:mysql> set password for root@localhost = password('123');
access转mysql教程视频
⽅法2:⽤mysqladmin
格式:mysqladmin -u⽤户名 -p旧密码 password 新密码
例⼦:mysqladmin -uroot -p123456 password 123
⽅法3:⽤UPDATE直接编辑user表
⾸先登录MySQL。
mysql> use mysql;
mysql> update user set password=password('123') where user='root' and host='localhost';
mysql> flush privileges;
⽅法4:在忘记root密码的时候,可以这样
以windows为例:
1. 关闭正在运⾏的MySQL服务。
2. 打开DOS窗⼝,转到mysql\bin⽬录。
3. 输⼊mysqld --skip-grant-tables 回车。--skip-grant-tables 的意思是启动MySQL服务的时候跳过权限表认证。
4. 再开⼀个DOS窗⼝(因为刚才那个DOS窗⼝已经不能动了),转到mysql\bin⽬录。
5. 输⼊mysql回车,如果成功,将出现MySQL提⽰符 >。
6. 连接权限数据库: use mysql; 。
7. 改密码:update user set password=password("123") where user="root";(别忘了最后加分号)。
8. 刷新权限(必须步骤):flush privileges; 
9. 退出 quit。
10. 注销系统,再进⼊,使⽤⽤户名root和刚才设置的新密码123登录。
情况⼆解决⽅案:远程授权
1. 先⽤localhost登录(进⼊MySQL) mysql -u root -p
Enter password: (输⼊密码)
2. 执⾏授权命令
mysql> grant all privileges on . to root@'%' identified by '123'; (注意语句后⾯的“;”)
Query OK, 0 rows affected (0.07 sec)
3. 退出再试: mysql> quit
4、再试登录: mysql -u root -h 192.168.194.142 -p
Enter password:
结果显⽰:Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 3
表⽰成功
下⾯详细说说如何给⽤户授权。
mysql> grant 权限1,权限2, ... 权限n on 数据库名称.表名称 to ⽤户名@⽤户地址 identified by '连接⼝令';
权限1,权限2,... 权限n 代表 select、insert、update、delete、create、drop、index、alter、grant、references、reload、shutdown、process、file 等14个权限。
当权限1,权限2,... 权限n 被 all privileges 或者 all 代替时,表⽰赋予⽤户全部权限。
当数据库名称.表名称被.代替时,表⽰赋予⽤户操作服务器上所有数据库所有表的权限。
⽤户地址可以是localhost,也可以是IP地址、机器名和域名。也可以⽤ '%' 表⽰从任何地址连接。
'连接⼝令' 不能为空,否则创建失败。
举⼏个例⼦:
mysql> grant select,insert,update,delete,create,drop ployee to joe@10.163.225.87 identified by ‘123′;
给来⾃10.163.225.87的⽤户joe分配可对数据库vtdc的employee表进⾏select,insert,update,delete,create,drop等操作的权限,并设定⼝令为123。
mysql> grant all privileges on vtdc.* to joe@10.163.225.87 identified by ‘123′;
给来⾃10.163.225.87的⽤户joe分配可对数据库vtdc所有表进⾏所有操作的权限,并设定⼝令为123。
mysql> grant all privileges on . to joe@10.163.225.87 identified by ‘123′;
给来⾃10.163.225.87的⽤户joe分配可对所有数据库的所有表进⾏所有操作的权限,并设定⼝令为123。
mysql> grant all privileges on . to joe@localhost identified by ‘123′;
给本机⽤户joe分配可对所有数据库的所有表进⾏所有操作的权限,并设定⼝令为123。案:远程授权

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。