Mac Mysql数据库中文乱码问题解决

所属分类: 数据库 / Mysql 阅读数: 848
收藏 0 赞 0 分享

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路径加入环境变量,有需要的朋友好按照下面的步骤操作即可
收藏 0 赞 0 分享

mysql 增加修改字段类型及删除字段类型

本节主要介绍了mysql如何增加修改字段类型及删除字段类型,需要的朋友可以参考下
收藏 0 赞 0 分享

Mysql主从复制(master-slave)实际操作案例

这篇文章主要介绍了Mysql主从复制(master-slave)实际操作案例,同时介绍了Mysql grant 用户授权的相关内容,需要的朋友可以参考下
收藏 0 赞 0 分享

MySQL异常处理浅析

这篇文章主要介绍了MySQL的异常处理,需要的朋友可以参考下
收藏 0 赞 0 分享

MySQL存储毫秒数据的方法

MySQL中没有可以直接存储毫秒数据的数据类型,但是不过MySQL却能识别时间中的毫秒部分。这篇文章主要介绍了MySQL存储毫秒数据的方法,需要的朋友可以参考下
收藏 0 赞 0 分享

MySql中使用INSERT INTO语句更新多条数据的例子

这篇文章主要介绍了MySql中使用INSERT INTO语句更新多条数据的例子,MySQL的特有语法,需要的朋友可以参考下
收藏 0 赞 0 分享

Windows下MySql错误代码1045的解决方法

这篇文章主要介绍了Windows下MySql错误代码1045的解决方法,文中还包含了2个Linux下的解决方法,需要的朋友可以参考下
收藏 0 赞 0 分享

mysql查询今天、昨天、近7天、近30天、本月、上一月的SQL语句

这篇文章主要介绍了mysql查询今天、昨天、近7天、近30天、本月、上一月的SQL语句,一般在一些统计报表中比较常用这个时间段,需要的朋友可以参考下
收藏 0 赞 0 分享

mysql的中文数据按拼音排序的2个方法

这篇文章主要介绍了mysql的中文数据按拼音排序的2个方法,用于一些特殊环境,需要的朋友可以参考下
收藏 0 赞 0 分享

MySQL定期分析检查与优化表的方法小结

听DBA的人说,相比oracle,MySQL就是一个玩具级别的数据库,在网易门户中,DBA基本很少去管理到MySQL的东西,所以我们产品使用到的MySQL的一些配置和优化还是需要我们开发人员自己动手,下面就简单介绍一下实用的定期优化方法
收藏 0 赞 0 分享
查看更多