ThinkPHP 连接MySQL 8 出现的utf8mb4字符集错误

报错:

SQLSTATE[HY000] [2054] Server sent charset unknown to the client. Please, report to the developers

解决:

在D:\phpStudy\PHPTutorial\MySQL下的my.ini中的mysqld下加如下语句

character-set-server = utf8mb4

collation-server = utf8mb4_unicode_ci


图1

重启PHPstudy,之后报错:

SQLSTATE[HY000] [2054] The server requested authentication method unknown to the client

解决:

bin目录下连接数据库,

mysql -u root -p

ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password by 'root';

注:by后面是数据库密码,自己设置

刷新权限

flush privileges;


然后再my.ini中的mysqld下面加

default_authentication_plugin = mysql_native_password   如图1所示



重启PHPstudy,连接成功

参考来源:

1.ThinkPHP 3.2 连接MySQL 8 出现的utf8mb4字符集错误


ThinkPHP 3.2 连接MySQL 8 出现的utf8mb4字符集错误

打印|推荐|评分

2018-9-20 03:48 PM

ThinkPHP 3.2 连接MySQL 8时报如下错误:

SQLSTATE[HY000] [2054] Server sent charset unknown to the client. Please, report to the developers

网上查询得知MySQL 8 默认字符集为utf8mb4,给出的解决方法都是设置MySQL的默认字符集为老版本的utf8,然而其实只需要在MySQL配置文件中[mysqld]下加这两行

character-set-server = utf8mb4

collation-server = utf8mb4_unicode_ci

同时在TP配置文件中的数据库连接信息中指明字符集utf8即可

'DB_CHARSET'=> 'utf8', // 字符集

如果又出现这样的报错:

QLSTATE[HY000] [2054] The server requested authentication method unknown to the client

是因为MySQL8中用户的认证类型(Authentication type)默认为cacheing sha2 password导致的错误,需要修改用户权限认证方式为5.x的认证方式

alter user 'root'@'%' identified with mysql_native_password by '123456';

#刷新权限

flush privileges;

然后在MySQL配置文件中[mysqld]下加上

default_authentication_plugin=mysql_native_password

你可能感兴趣的:(ThinkPHP 连接MySQL 8 出现的utf8mb4字符集错误)