如何解决尽管使用utf8mb4 / utf8mb4_general_ci创建表,但无法将中文字符插入MySQL数据库
我已经阅读了很多关于Stackoverflow的帖子,并且总体而言,它们似乎仍然无法解决我的情况。
在PHP 7.4上运行Laravel 7.x,我正在使用Laravel-Excel导入数据库。屏幕截图显示了我的database.php和表具有推荐的utf8mb4设置。但是,它抱怨有中文字符的列,当我用英文替换时,输入就通过了。我不在这里做直接的数据库写操作,因为Laravel-Excel通过在控制器中调用Excel :: import来做到这一点。
我还能采取其他步骤吗?
SHOW CREATE TABLE结尾于:
ENGINE=INNODB AUTO_INCREMENT=15735 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin
类似于“ char%”的显示变量给出:
"Variable_name" "Value"
"character_set_client" "utf8"
"character_set_connection" "utf8"
"character_set_database" "utf8mb4"
"character_set_filesystem" "binary"
"character_set_results" "utf8"
"character_set_server" "latin1"
"character_set_system" "utf8"
"character_sets_dir" "C:\\xampp\\mysql\\share\\charsets\\"
解决方法
以下db /表更改:
ALTER DATABASE <mydb> CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_520_ci;
ALTER TABLE <mytable> CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_520_ci;
以及database.php中的更改:
...
'collation' => 'utf8mb4_unicode_520_ci',...
为我解决了这个问题。 php.ini已经具有正确的设置。
感谢@RickJames
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。