0

0

命令行下MySQL中文乱码如何设置utf8编码

下次还敢

下次还敢

发布时间:2025-07-02 11:31:01

|

940人浏览过

|

来源于php中文网

原创

mysql命令行中文乱码解决方法是统一各环节字符集为utf8mb4。具体步骤如下:1.查看当前编码设置,确认character_set相关变量是否为utf8或utf8mb4;2.修改配置文件,在[client]和[mysqld]下设置默认字符集为utf8mb4并重启服务;3.修改已有数据库和表的字符集,使用alter database和alter table语句转换编码;4.命令行连接时指定--default-character-set=utf8mb4参数或执行set names 'utf8mb4'临时设置;5.检查字段定义是否支持中文,通过show create table确认字段字符集,必要时用modify修改字段编码。完成上述步骤后可彻底解决中文乱码问题。

命令行下MySQL中文乱码如何设置utf8编码

MySQL在命令行下出现中文乱码,通常是因为字符编码设置不一致导致的。解决这个问题的关键在于统一客户端、连接、服务器和数据库这几个环节的字符集为utf8或utf8mb4。


查看当前编码设置

在操作之前,先确认当前MySQL的各项编码设置:

SHOW VARIABLES LIKE 'character_set%';
SHOW VARIABLES LIKE 'collation%';

你会看到类似以下的输出:

+--------------------------+----------------------------+
| Variable_name            | Value                      |
+--------------------------+----------------------------+
| character_set_client     | latin1                     |
| character_set_connection | latin1                     |
| character_set_database   | latin1                     |
| character_set_results    | latin1                     |
| character_set_server     | latin1                     |
+--------------------------+----------------------------+

如果这些值不是 utf8utf8mb4,那就需要调整了。


设置默认字符集为utf8mb4

修改配置文件(通常是 /etc/my.cnf/etc/mysql/my.cnf):

[client]
default-character-set=utf8mb4

[mysqld]
character-set-server=utf8mb4
collation-server=utf8mb4_unicode_ci

保存后重启MySQL服务:

sudo systemctl restart mysql

这样可以让MySQL在启动时默认使用utf8mb4编码。


修改已有数据库和表的字符集

如果你已经有数据库和数据表,还需要单独修改它们的字符集:

SDCMS-B2C商城网站管理系统
SDCMS-B2C商城网站管理系统

SDCMS-B2C商城网站管理系统是一个以php+MySQL进行开发的B2C商城网站源码。 本次更新如下: 【新增的功能】 1、模板引擎增加包含文件父路径过滤; 2、增加模板编辑保存功能过滤; 3、增加对统计代码参数的过滤 4、新增会员价设置(每个商品可以设置不同级不同价格) 5、将微信公众号授权提示页单独存放到data/wxtemp.php中,方便修改 【优化或修改】 1、修改了check_b

下载
  1. 修改数据库编码:
ALTER DATABASE your_database CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
  1. 修改数据表编码:
ALTER TABLE your_table CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
注意:修改表结构会重建表,可能会对性能有影响,建议在低峰期操作。

命令行连接时指定字符集

有时候即使设置了全局编码,通过命令行连接时也可能因为客户端默认编码问题导致乱码。可以在登录时显式指定字符集:

mysql -u username -p --default-character-set=utf8mb4

或者在MySQL中临时设置:

SET NAMES 'utf8mb4';

这个命令相当于同时设置了 character_set_client, character_set_connection, 和 character_set_results 为utf8mb4。


检查字段定义是否支持中文

有些时候虽然整体编码都改了,但个别字段还是用的latin1。可以检查一下具体字段的编码:

SHOW CREATE TABLE your_table;

确保字段定义中的字符集是utf8mb4,例如:

CREATE TABLE example (
  id INT PRIMARY KEY,
  content TEXT CHARSET utf8mb4
);

如果不是的话,可以用下面语句修改字段编码:

ALTER TABLE your_table MODIFY column_name VARCHAR(255) CHARACTER SET utf8mb4;

基本上就这些。只要把客户端、连接、服务器、数据库、数据表、字段这几层的字符集都统一成utf8或utf8mb4,中文乱码的问题基本就能解决。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

662

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

246

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

281

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

514

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

253

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

386

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

529

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

599

2023.08.14

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

9

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号