尽管用 utf8mb4/utf8mb4_general_ci 创建了 table,但无法将汉字插入到 MySQL 数据库中
Unable to insert Chinese characters into MySQL db Despite creating table with utf8mb4/utf8mb4_general_ci
我已经阅读了很多关于 Whosebug 的帖子,但它们似乎仍然没有解决我的情况。
运行 Laravel 7.x 在 PHP 7.4 上,我正在使用 Laravel-Excel 导入数据库。屏幕截图显示我的 database.php 和 table 具有推荐的 utf8mb4 设置。然而,它抱怨有中文字符的列,当我用英文替换时,导入会顺利通过。我没有在此处直接写入数据库,因为 Laravel-Excel 通过在我的控制器中调用 Excel::import 来执行此操作。
我可以采取其他步骤吗?
SHOW CREATE TABLE 结束于:
ENGINE=INNODB AUTO_INCREMENT=15735 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin
SHOW VARIABLES LIKE '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/ table 更改:
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
我已经阅读了很多关于 Whosebug 的帖子,但它们似乎仍然没有解决我的情况。
运行 Laravel 7.x 在 PHP 7.4 上,我正在使用 Laravel-Excel 导入数据库。屏幕截图显示我的 database.php 和 table 具有推荐的 utf8mb4 设置。然而,它抱怨有中文字符的列,当我用英文替换时,导入会顺利通过。我没有在此处直接写入数据库,因为 Laravel-Excel 通过在我的控制器中调用 Excel::import 来执行此操作。
我可以采取其他步骤吗?
SHOW CREATE TABLE 结束于:
ENGINE=INNODB AUTO_INCREMENT=15735 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin
SHOW VARIABLES LIKE '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/ table 更改:
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