mac下修改mysql默认字符集为utf8

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介:

1、首先检查默认安装的字符集

[html]  view plain  copy
 print ?
  1. mysql> show variables like '%char%';  
  2. +--------------------------+--------------------------------------------------------+  
  3. | Variable_name            | Value                                                  |  
  4. +--------------------------+--------------------------------------------------------+  
  5. | character_set_client     | utf8                                                   |  
  6. | character_set_connection | utf8                                                   |  
  7. | character_set_database   | latin1                                                   |  
  8. | character_set_filesystem | binary                                                 |  
  9. | character_set_results    | utf8                                                   |  
  10. | character_set_server     | latin1                                                   |  
  11. | character_set_system     | utf8                                                   |  
  12. | character_sets_dir       | /usr/local/mysql-5.6.23-osx10.8-x86_64/share/charsets/ |  
  13. +--------------------------+--------------------------------------------------------+  
  14. 8 rows in set (0.00 sec)  

character_set_database和character_set_server依然是latin1的字符集,也就是说mysql后续创建的表都是latin1字符集的,不是utf8,会造成一些麻烦。所以有必要修改my.cnf,在修改my.cnf之前一定要关闭mysql进程,不然会遇到mysql的sock不能连接的问题。


2、查看是否有my.cnf文件在/etc/目录下

[html]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. ls -al /etc/  

检查了一下,发现本机没有my.cnf,查看了很多资料,他们说可以去/usr/local/mysql的安装目录下找到support-files,复制下面格式类似my-**.cnf的文件到/etc/目录下即可。命令如下:

[html]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. cp /usr/local/mysql/support-files/my-default.cnf /etc/  


3、修改/etc/my-default.cnf文件名为my.cnf,并修改里面的配置

[html]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. cat /etc/my.cnf  

查看配置文件的内容

[html]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. ls -l /etc/my.cnf  

查看文件的读写权限,如果为644(rw- r-- r--)则改为(664) (rw- rw- r--)

如果改为(666)(rw- rw- rw-)则修改以后配置文件不会生效。下面详细讲解为什么不会生效。

[html]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. sudo chmod 664 /etc/my.cnf  

输入密码即可。


4、修改配置文件内容

[html]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. vi /etc/my.cnf  

在文件最上面加上

[html]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. [client]  
  2. default-character-set=utf8  

在[mysqld]下增加

[html]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. character-set-server=utf8  

键入:wq!保存并退出


5、重新查看编码集

[html]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. mysql> show variables like '%char%';  
  2. +--------------------------+--------------------------------------------------------+  
  3. | Variable_name            | Value                                                  |  
  4. +--------------------------+--------------------------------------------------------+  
  5. | character_set_client     | utf8                                                   |  
  6. | character_set_connection | utf8                                                   |  
  7. | character_set_database   | utf8                                                   |  
  8. | character_set_filesystem | binary                                                 |  
  9. | character_set_results    | utf8                                                   |  
  10. | character_set_server     | utf8                                                   |  
  11. | character_set_system     | utf8                                                   |  
  12. | character_sets_dir       | /usr/local/mysql-5.6.23-osx10.8-x86_64/share/charsets/ |  
  13. +--------------------------+--------------------------------------------------------+  
  14. 8 rows in set (0.00 sec)  


出现问题详解:

一开始我输入的命令为

[html]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. <span style="color:#ff0000;">chmod a+w /etc/my.cnf</span>  
这条命令的意思是my.cnf对所有用户都有写的权限,这样就变成了666了。导致我改完以后也不报错,也不生效。

直到我关闭了数据库服务,再进入数据库的时候,数据库出现一个错误

[html]  view plain  copy
 print ? 在CODE上查看代码片 派生到我的代码片
  1. <span style="color:#ff0000;">World-writable config file '/etc/my.cnf' is ignored</span>  

大概意思是权限全局可写,任何一个用户都可以写。mysql担心这种文件被其他用户恶意修改,所以忽略掉这个配置文件。

一下子我就懂了,打开数据库服务,修改成664后,再重启数据库,再查看编码已经成功修改。

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
1月前
|
关系型数据库 MySQL 存储
【MySQL】——数据类型及字符集
【MySQL】——数据类型及字符集
167 0
【MySQL】——数据类型及字符集
|
4月前
|
存储 关系型数据库 MySQL
Mysql中utf8和utf8mb4区别
Mysql中utf8和utf8mb4区别
44 0
|
1月前
|
存储 人工智能 搜索推荐
详解MySQL字符集和Collation
MySQL支持了很多Charset与Collation,并且允许用户在连接、Server、库、表、列、字面量多个层次上进行精细化配置,这有时会让用户眼花缭乱。本文对相关概念、语法、系统变量、影响范围都进行了详细介绍,并且列举了有可能让字符串发生字符集转换的情况,以及来自不同字符集的字符串进行比较等操作时遵循的规则。对于最常用的基于Unicode的字符集,本文介绍了Unicode标准与MySQL中各个字符集的关系,尤其详细介绍了当前版本(8.0.34)默认字符集utf8mb4。
|
1月前
|
存储 人工智能 关系型数据库
详细介绍TiDB 与 MySQL 中的常用字符集及排序规则
一文理清 TiDB 与 MySQL 中的常用字符集及排序规则
122 6
|
5月前
|
关系型数据库 MySQL Docker
Mac Docker 安装MySQL
Mac Docker 安装MySQL
110 1
|
2月前
|
存储 关系型数据库 MySQL
【2024】新建mysql数据库,如何选择字符集和排序规则
【2024】新建mysql数据库,如何选择字符集和排序规则
156 1
|
2月前
|
NoSQL 关系型数据库 MySQL
Windows、Linux、Mac安装数据库(mysql、MongoDB、Redis)#0
不同系统下进行MySQL安装、MongoDB安装、Redis安装【2月更文挑战第5天】
444 5
Windows、Linux、Mac安装数据库(mysql、MongoDB、Redis)#0
|
2月前
|
关系型数据库 MySQL 数据安全/隐私保护
【MySQL】 Docker 安装 MySQL8.0(mac)
【MySQL】 Docker 安装 MySQL8.0(mac)
|
2月前
|
存储 关系型数据库 MySQL
从零开始学Mysql - 字符集和编码(下)
从零开始学Mysql - 字符集和编码(下)
109 0
|
2月前
|
存储 SQL 关系型数据库
从零开始学Mysql - 字符集和编码(上)
从零开始学Mysql - 字符集和编码(上)
137 0