Mac 下MySQL数据库中文乱码解决方案:
当我们用框架进行数据库的存储操作时,经常会遇到中文乱码的问题。
如:在使用Java中得SSH框架时,我们需要在web.xml文件中配置编码的filter,具体代码是:
span style="font-family:FangSong_GB2312;font-size:14px;">!-- 表单处理乱码,必须在OpenSessionInViewFilter的filter之前 -->
filter>
filter-name>CharacterFilter/filter-name>
filter-class>org.springframework.web.filter.CharacterEncodingFilter/filter-class>
init-param>
param-name>encoding/param-name>
param-value>UTF-8/param-value>
/init-param>
/filter>
filter-mapping>
filter-name>CharacterFilter/filter-name>
url-pattern>/*/url-pattern>
/filter-mapping>/span>
然后进行数据库存储的时候发现存储到数据库的中文还是乱码,这个时候调试项目发现最后传入SQL的参数值已经是正常的中文了,
那么这个时候我们就需要查看下数据库的编码了。
使用SQL命令查看默认的编码格式:
span style="font-family:FangSong_GB2312;font-size:14px;">show variables like "%char%";/span>
查看test数据库的编码格式:
span style="font-family:FangSong_GB2312;font-size:14px;">show create database test;/span>
然后我们进行Max下的MySQL编码修改:
由于Mac版的MySql默认字符集不是utf-8,所以需要如下步骤来进行修改
在 终端中输入
span style="font-family:FangSong_GB2312;font-size:14px;">sudo -s/span>
然后提示输入密码,此密码为系统密码!
在命令行中输入
span style="font-family:FangSong_GB2312;font-size:14px;">cd /usr/local/mysql/support-files/span>
继续输入(拷贝文件到etc目录下)
span style="font-family:FangSong_GB2312;font-size:14px;">cp my-default.cnf /etc/my.cnf/span>
继续输入(进入etc目录)
span style="font-family:FangSong_GB2312;font-size:14px;">cd /etc/span>
继续输入
span style="font-family:FangSong_GB2312;font-size:14px;">vimy.cnf/span>
这个时候,你会发现用vi工具打开了my.cnf文件,它的光标的上下左右移动是通过键盘上的h、j、k、l这几个按键,Mac系统版本不一样10.9.3系统光标是键是起作用的!
然后按j键 把光标移动到[client]的最后,添加一个属性:(或使用下键)
span style="font-family:FangSong_GB2312;font-size:14px;">default-character-set=utf8(此属性mysql 5.5之后不能够在
mysqld下面增加,也就是5.5以前的版本,之后的版本忽略此属性)/span>
继续按下键,把光标移动到[mysqld]后面,添加3个属性
span style="font-family:FangSong_GB2312;font-size:14px;">default-storage-engine=INNODB
character-set-server=utf8
collation-server=utf8_general_ci/span>
按键盘左上角的esc键推出编辑模式,然后输入一个冒号和字母x
重启MySql服务
此时再次执行数据库操作,中文已经可以正常存储了!
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
您可能感兴趣的文章:- 教你如何在Mac上安装mysql数据库
- MAC下MYSQL数据库密码忘记的解决办法
- Mac环境下php操作mysql数据库的方法分享
- mac安装mysql数据库及配置环境变量的图文教程