mysql终端插入中文乱码解决办法

旧城等待, 2022-09-25 01:15 347阅读 0赞

虚拟机新装的mysql启动后,命令行插入中文乱码

首先查看下编码

  1. mysql> show variables like 'character%';
  2. +--------------------------+----------------------------+
  3. | Variable_name | Value |
  4. +--------------------------+----------------------------+
  5. | character_set_client | latin1 |
  6. | character_set_connection | latin1 |
  7. | character_set_database | latin1 |
  8. | character_set_filesystem | binary |
  9. | character_set_results | latin1 |
  10. | character_set_server | latin1 |
  11. | character_set_system | utf8 |
  12. | character_sets_dir | /usr/share/mysql/charsets/ |
  13. +--------------------------+----------------------------+
  14. 8 rows in set (0.00 sec)

mysql有六处使用了字符集,分别为:client 、connection、database、results、server 、system。其中与服务器端相关:database、server、system(永远无法修改,就是utf-8);与客户端相关:connection、client、results 。

client为客户端使用的字符集。
connection为连接数据库的字符集设置类型,如果程序没有指明连接数据库使用的字符集类型则按照服务器端默认的字符集设置。
database为数据库服务器中某个库使用的字符集设定,如果建库时没有指明,将使用服务器安装时指定的字符集设置。
results为数据库给客户端返回时使用的字符集设定,如果没有指明,使用服务器默认的字符集。
server为服务器安装时指定的默认字符集设定。
system为数据库系统使用的字符集设定。

修改配置
cp /etc/my.cnf /etc/my.cnf.bak
vi /etc/my.cnf

#分别在client和mysqld添加

  1. [client]
  2. default-character-set=utf8
  3. [mysqld]
  4. character-set-server=utf8

然后重启mysql

service mysqld restart

查看是否修改成功

  1. mysql> show variables like 'character%';
  2. +--------------------------+----------------------------+
  3. | Variable_name | Value |
  4. +--------------------------+----------------------------+
  5. | character_set_client | utf8 |
  6. | character_set_connection | utf8 |
  7. | character_set_database | utf8 |
  8. | character_set_filesystem | binary |
  9. | character_set_results | utf8 |
  10. | character_set_server | utf8 |
  11. | character_set_system | utf8 |
  12. | character_sets_dir | /usr/share/mysql/charsets/ |
  13. +--------------------------+----------------------------+

然后重开个终端进行中文插入测试ok

mysql有六处使用了字符集,分别为:client 、connection、database、results、server 、system。其中与服务器端相关:database、server、system(永远无法修改,就是utf-8);与客户端相关:connection、client、results 。

client为客户端使用的字符集。
connection为连接数据库的字符集设置类型,如果程序没有指明连接数据库使用的字符集类型则按照服务器端默认的字符集设置。
database为数据库服务器中某个库使用的字符集设定,如果建库时没有指明,将使用服务器安装时指定的字符集设置。
results为数据库给客户端返回时使用的字符集设定,如果没有指明,使用服务器默认的字符集。
server为服务器安装时指定的默认字符集设定。
system为数据库系统使用的字符集设定。

发表评论

表情:
评论列表 (有 0 条评论,347人围观)

还没有评论,来说两句吧...

相关阅读

    相关 weka中文解决办法

    由于weka的默认字符集编码是Cp1252,所以如果你导入的数据中有中文字符,就会出现乱码的情况,所以需要weka的RunWeka.ini文件 将cp1252替换成你的数据对