Linux下修改MySQL编码的方法 影响项目乱码问题

本文指导如何在CentOS环境下通过修改MySQL配置文件来调整编码设置,确保客户端与服务器之间的数据交流采用UTF8编码,并演示了创建UTF8编码数据库的方法,解决了直接创建表存入中文导致显示为问号的问题。
默认登录mysql之后可以通过SHOW VARIABLES语句查看系统变量及其值。
  mysql> show variables like '%character%';
-------------------------- ----------------------------
| Variable_name | Value |
-------------------------- ----------------------------
| character_set_client |latin1 |
| character_set_connection | latin1 |
| character_set_database | latin1 |
| character_set_filesystem | binary |
| character_set_results | latin1 |
| character_set_server | latin1  |
| character_set_system | utf8 |
| character_sets_dir | /usr/share/mysql/charsets/ |
-------------------------- ---------------------------- 

说明:以下是在CentOS-6.2下的设置  (不同的版本可能有些差异,比如文件的位置。但设置的内容应该是一样的)
1. 找到mysql的配置文件,拷贝到etc目录下,第一步很重要
  把/usr/share/doc/mysql-server-5.1.52/my-large.cnf 复制到 /etc/my.cnf
  即用命令:cp /usr/share/doc/mysql-server-5.1.52/my-large.cnf  /etc/my.cnf
2. 打开my.cnf修改编码
  在[client]下增加default-character-set=utf8
  在[mysqld]下增加default-character-set=utf8
  同时加上init_connect='SET NAMES utf8' (设定连接mysql数据库时使用utf8编码,以让mysql数据库为utf8运行)
3.重新启动mysql
  service mysqld restart
  再次输入show variables like '%character%';
-------------------------- ----------------------------
| Variable_name | Value |
-------------------------- ----------------------------
| character_set_client | utf8 |
| character_set_connection |  utf8 |
| character_set_database |  utf8 |
| character_set_filesystem | binary |
| character_set_results |  utf8 |
| character_set_server |  utf8 |
| character_set_system | utf8 |
| character_sets_dir | /usr/share/mysql/charsets/ |
-------------------------- ---------------------------- 
  即使做了以上修改如果直接数据库再创建表,然后存入中文,取出来的会是问号。解决的办法是:创建数据库的时候指明默认字符集为utf8,如:
  create database test default character set utf8;


详细出处参考:http://www.jb51.net/article/30104.htm

转载于:https://my.oschina.net/jiefalcon/blog/162511

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值