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

 更新时间:2016年10月28日 10:58:51   投稿:lqh  
这篇文章主要介绍了Mac Mysql数据库中文乱码问题解决的相关资料,需要的朋友可以参考下

脚本之家 / 编程助手:解决程序员“几乎”所有问题!
脚本之家官方知识库 → 点击立即使用

Mac 下MySQL数据库中文乱码解决方案:

当我们用框架进行数据库的存储操作时,经常会遇到中文乱码的问题。

如:在使用Java中得SSH框架时,我们需要在web.xml文件中配置编码的filter,具体代码是:

1
2
3
4
5
6
7
8
9
10
11
12
13
<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个属性

1
2
3
4
5
<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服务

此时再次执行数据库操作,中文已经可以正常存储了!

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

蓄力AI

微信公众号搜索 “ 脚本之家 ” ,选择关注

程序猿的那些事、送书等活动等着你

相关文章

  • MySQL binlog日志清理的方案分享

    MySQL binlog日志清理的方案分享

    Binlog日志非常重要,但是占用的磁盘空间也很大,我们也需要定期的去清理二进制日志,在MySQL数据库中,提供了自动清理Binlog日志的参数,本文给大家详细介绍了MySQL binlog日志清理方案,需要的朋友可以参考下
    2024-01-01
  • MySQL Threads_running飙升与慢查询的相关问题解决

    MySQL Threads_running飙升与慢查询的相关问题解决

    这篇文章主要介绍了MySQL Threads_running飙升与慢查询的问题解决,帮助大家更好的理解和学习使用MySQL数据库,感兴趣的朋友可以了解下
    2021-05-05
  • Mysql常见问题集锦

    Mysql常见问题集锦

    Mysql在使用过程中难免会遇到一些问题,在本文把常见问题做个记录方便以后发现问题查看,感兴趣的朋友也可以了解下
    2013-09-09
  • mysql 关键词相关度排序方法详细示例分析

    mysql 关键词相关度排序方法详细示例分析

    以下是对mysql关键词相关度排序方法进行了详细的分析介绍,需要的朋友可以过来参考下
    2013-08-08
  • 浅谈mysql一张表到底能存多少数据

    浅谈mysql一张表到底能存多少数据

    这篇文章主要介绍了浅谈mysql一张表到底能存多少数据,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03
  • MySql数据库基础之子查询详解

    MySql数据库基础之子查询详解

    所谓子查询是指在一个查询中嵌套了其他的若干查询,即在一个SELECT查询语句的WHERE或FROM子句中包含另一个SELECT查询语句,下面这篇文章主要给大家介绍了关于MySQL子查询的相关资料,需要的朋友可以参考下
    2022-09-09
  • 详解Navicat远程连接mysql很慢

    详解Navicat远程连接mysql很慢

    这篇文章主要介绍了详解Navicat远程连接mysql很慢(以及数据库连接报错"Too many connections")解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • MySQL与PHP的基础与应用专题之增删改查

    MySQL与PHP的基础与应用专题之增删改查

    MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,本系列将带你掌握php与mysql的基础应用,本篇从数据库的增删改查开始
    2022-02-02
  • 简单谈谈MySQL的半同步复制

    简单谈谈MySQL的半同步复制

    从MySQL5.5开始,MySQL以插件的形式支持半同步复制。如何理解半同步呢?今天我们就来详细讲解下,希望大家能够喜欢。
    2017-03-03
  • MySQL8.0.11安装总结教程图解

    MySQL8.0.11安装总结教程图解

    本文通过图文并茂的形式给大家介绍了MySQL8.0.11安装总结,非常不错,具有参考借鉴价值,需要的朋友参考下吧
    2018-05-05

最新评论