Navicat连接mysql数据库(docker里的实例)的错误1251

环境:
Centos 7.2
Docker-ce

首先,我安装了mysql

docker search mysql
在这里插入图片描述
用的是这个镜像。

使用下面语句创建

docker run -itd \
--name lnmp_mysql \
-p 3306:3306 \
-v /sql_data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=my-secret-pw \
docker.io/mysql

下面开始用navicat连接。

出现1251错误
在这里插啊啊入图片描述
出现这个问题的原因

user的权限限制问题

来说说权限问题,这个问题。

很简单,只需要进入目标容器,修改mysql的user表就可以

#
docker  ps  -q #查看容器ID
#
docker exec -it lnmp_mysql bash  #为容器分配一个伪终端
#########进入后#######
#
#mysql -uroot -p
#
#my-secret-pw
#
#ALTER user 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456'; 
#
修改完之后重启lnmp_mysql
#docker restart lnmp_mysql

在这里插入图片描述

成功了!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值