linux mysql 输入中文_mysql出现中文乱码或不能输入中文问题的Windows或Linux系统解决方法...

mysql出现中文乱码或不能输入中文问题的Windows或Linux系统解决方法

原创 2016年08月27日 21:07:57 阅读 3649

相信MySQL新手在刚接触MySQL时总会遇到中文乱码的问题,如ERROR 1366 (HY000): Incorrect string value。作为新手,我也遇到过。不过以前没系统地找过解决方法,最近因为Linux要安装MySQL,我遇到了在MySQL命令行中中文不能输入和中文乱码的问题,就查找解决方法解决,顺带把windows系统中文乱码的问题给解决了。下面我将分别介绍如何在Windows和Linux系统解决类似的问题。

一. Windows环境下:

在mysql安装目录下找到my.ini文件,注意是安装目录下,而不是安装目录下的bin目录下,否则修改了也不会生效。我就犯了这样的错误。如果安装目录下没有,就把my-medium.ini复制(注意是复制,不要覆盖或删除掉,以防可能出现未知的错误)重命名为my.ini,然后做如下添加:

[client]

default-character-set=utf8

[mysqld]

collation-server=utf8_general_ci

character_set_server=utf8

[mysql]

default-character-set=utf8

然后重启mysql服务(net start mysql)即可。在命令行输入status或show variables like 'character%';发现编码方式变成了utf8。

二. Linux环境下:(注:我的系统是Centos7.2 64位,用RPM方式安装的MySQL,不一样的系统和安装方式可能处理方法不一样。)

mysql不支持输入中文的解决方法:可能是因为shell不支持中文,这是Linux环境配置问题,需要打开locale.conf文件,即vim /etc/locale.conf,然后做如下修改:

LANG="en_US.UTF-8"。

mysql中文乱码出现ERROR 1366 (HY000): Incorrect string value错误解决方法:

1.直接解决方法通过改配置文件:

#vim /etc/my.cnf(5.5以后MySQL) 做如下添加:

[client]

port=3306

default-character-set=utf8

[mysql]

default-character-set=utf8

[mysqld]

collation-server=utf8_general_ci

character_set_server=utf8

然后重启mysql服务,在命令行输入status或show variables like 'character%';发现编码方式变成了utf8。

2.间接解决方法通过修改数据库、表的编码方式

建表之前指定编码方式:create table  tablename (...) default charset=utf8

改变已建立的数据库:alter database databasename character set utf8;

改变已建立的表:alter table tablename convert to character set utf8;

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值