解决MySQL新建用户本地无法登陆问题

本文介绍如何检查MySQL用户表中是否存在新用户及其host设置,并通过实例解释为何需要为超级用户同时配置'%'和'localhost' host的重要性。

1. 查看用户表是否有新用户及新用户的host是否为‘%’

  select host,user,password from mysql.user;

2. 如果只有一个host为‘%’的用户,根据MySQL手册下面的描述:

  其中两个账户有相同的用户名monty和密码some_pass。两个账户均为超级用户账户,具有完全的权限可以做任何事情。一个账户 ('monty'@'localhost')只用于从本机连接时。另一个账户('monty'@'%') 可用于从其它主机连接。请注意monty的两个账户必须能从任何主机以monty连接。没有localhost账户,当monty从本机连接 时,mysql_install_db创建的localhost的匿名用户账户将占先。结果是,monty将被视为匿名用户。原因是匿名用户账户的 Host列值比'monty'@'%'账户更具体,这样在user表排序顺序中排在前面。

  根据这段话的意思再添加一个用户名一样,host为‘localhost’的用户即可。

转载于:https://www.cnblogs.com/wanggs/p/5034591.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值