尽管使用utf8mb4/utf8mb4_general_ci创建表,但无法将中文插入MySQL数据库

问题描述 投票:0回答:1

我在 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\\"

laravel laravel-7 laravel-excel utf8mb4 php-7.4
1个回答
1
投票

以下数据库/表更改:

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

© www.soinside.com 2019 - 2024. All rights reserved.