`
bugyun
  • 浏览: 556952 次
社区版块
存档分类
最新评论

mysql配置utf8_mb4【转】

 
阅读更多

转:https://www.cnblogs.com/hark0623/p/7599899.html

http://blog.csdn.net/u013145194/article/details/51527389

注:以上是转载,但我实际使用的时候,修改配置文件重启数据库,然后修改表的类型即可

 

20180628补充

我现在使用的是ucloud的云数据库,发现在控制台无论怎么set修改数据库的类型,表类型,字段类型都是不行的。

需要修改云数据库的配置文件character_set_server=utf8mb4,然后再重启才能真正utf8mb4生效。

浪费了两个多小时。 

 

20180629补充

我再往另外的数据导入的时候,反而没有问题。 这次导入我使用的是mysqldump,嗯,之前有问题时使用的是sqoop,那么应该是sqoop client端的问题了。

1.修改mysql的配置文件

找到/etc/mysql路径下的my.cnf文件,通过vi命令打开该文件并进行编辑,需添加如下所示配置:

[client]

default-character-set=utf8mb4

 

[mysqld]

character-set-client-handshake = FALSE

character-set-server = utf8mb4

collation-server = utf8mb4_unicode_ci

init_connect=’SET NAMES utf8mb4'

 

[mysql]

default-character-set=utf8mb4

 

修改完毕之后,通过wq保存退出

2.修改database/table和column的字符集

进入mysql中,按下述所示进行命令的执行:

1) 修改database的字符集:

ALTER DATABASE 数据库名 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci;

示例:

ALTER DATABASE xxxdb CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci;

2) 步骤1)执行完成之后,需要执行use 数据库名,指明当前需要进行字符集修改的数据库;示例:use xxxdb;

3)修改table的字符集:

ALTER TABLE 表名 CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

示例:

ALTER TABLE user_comments CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

4) 修改column的字符集:

ALTER TABLE 表名 CHANGE 字段名 字段名 该字段原来的数据类型 CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

示例:

ALTER TABLE user_comments CHANGE content content TEXT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

 

上述修改完毕,exit退出mysql

3.重启mysql

这里重启的时候我一开始用的是service mysql restart,最后发现这条命令并不管用,重启没有成功,导致后面查看字符集的时候,并没有达到想要的字符集的状态。
所以采用下面的方法才可以正确的重启mysql.

3.1停止msql的运行

通过/etc/init.d/mysql执行stop命令

3.2启动mysql

通过/etc/init.d/mysql执行start命令

4.检查字符集:

进入mysql中,用SHOW VARIABLES WHERE Variable_name LIKE 'character\_set\_%' OR Variable_name LIKE 'collation%';命令查看字符集的情况

 

上述步骤实现之后便可成功使用emoji表情存储进mysql数据库的功能了。

 

————————————————————————————————————————————————————————————————

由于mysql数据库是需要备份和还原的,所以带有emoji表情的.sql文件的导入和导出的时候需要注意执行时的编码格式,以下为导入与导出的具体操作:

 

5.带有emoji表情的sql文件的导入与导出(主要为windows中的导出)

(若是在服务端的代码中的导出为:mysqldump –default-character-set-utf8mb4 –u 用户名 –p 数据库名 > 导出该文件的物理路径;导入的命令不需要指明编码格式,只需要正常的执行命令便可)

5.1导出

在进行把后缀名为.sql的文件,且文件数据中包含emoji表情的数据,进行备份导出的时候,此时不要使用第三方软件进行导出,而是使用命令行的形式执行该导出动作,其主要原因是使用第三方导出该文件时,由于其默认的导出的编码格式为utf-8,该编码格式最多只支持3个字节,而一个emoji表情有4个字节,这将导致emoji表情的数据变成乱码。所以在本地导出的时候具体操作步骤如下:

一、 打开cmd,先找到mysqldump这个执行文件所在的路径;

二、 在路径后输入mysqldump –default-character-set-utf8mb4 –u 用户名 –p 数据库名 > 导出该文件的物理路径,按“Enter”,即可完成导出功能,在导出的物理路径中即可找到已被导出的该文件。

5.2导入

把Linux系统中的.sql文件导入到本地的时候,不要使用Navicat Premium来进行导入,而是使用如下所示的命令行中的source .sql文件的物理路径,来进行如下的导入。

 

分享到:
评论

相关推荐

    MySQL 编码utf8 与 utf8mb4 utf8mb4_unicode_ci 与 utf8mb4_general_ci

    为了设置服务器默认的字符集为`utf8mb4`,你需要修改MySQL的配置文件`my.cnf`。对于MySQL 5.7,你可以在`[mysqld]`部分添加以下内容: ```ini init_connect='SET collation_connection = utf8mb4_unicode_ci' init_...

    如何更改MySQL数据库的编码为utf8mb4

    MySQL数据库的编码转换至utf8mb4是为了更好地支持Unicode字符集,尤其是对于包含四字节表情符号和其他特殊字符的数据。utf8mb4是utf8的扩展,它不仅完全兼容utf8,还能处理更多的Unicode字符范围,包括现代社交媒体...

    emoji入库mysql注意事项除了更改utf8mb4最大的坑在这里

    - **PDO连接字符串中指定字符集**:在使用PDO连接MySQL时,务必在连接字符串中指定`charset=utf8mb4`,以确保MySQL使用`utf8mb4`字符集接收数据。示例代码如下: ```php $pdo = new PDO("mysql:host=localhost;...

    Mysql支持emoji 表情符号 升级编码为UTF8MB4

    Mysql支持emoji表情符号升级编码为UTF8MB4 在使用Mysql数据库时,如果需要支持emoji表情符号,需要对数据库的编码进行升级,以便正确地存储和显示emoji表情符号。下面是升级Mysql编码为UTF8MB4的步骤和注意事项: ...

    Spring Data Jpa Mysql使用utf8mb4编码的示例代码

    在本文中,服务器数据库使用的是 utf8mb4_unicode_ci,而本地数据库使用的是 utf8_general_ci,这就导致了新表和旧表无法建立外键的问题。 知识点 3: 解决数据库字符集和排序规则不一致的问题 解决该问题可以从两...

    windows配置mysql5.7的字符集为utf8mb4 ----my.ini

    版本:mysql5.7 环境:windows 备注:配置mysql的字符集为utf8mb4 *为了解决mysql乱码参考了几个博客,只能在此鸣谢一下所有提供有价值的博客作者,此文件就上传备份一下

    更改MySQL数据库的编码为utf8mb4_wo.pdf

    MySQL 数据库编码修改为 utf8mb4 在 MySQL 数据库中,默认的编码方式为 utf8,但是 utf8 编码只支持最多 3 字节的数据,而 emoji 表情字符是 4 字节的字符。如果直接往采用 utf-8 编码的数据库中插入表情数据,Java...

    flowable相关数据库表mysql, 包含两种字符集utf8 和 utf8bm4

    添加flowable依赖,配置完成数据库连接,项目第一次启动会初始化数据库flowable相应的表,默认会加载的字符集为utf8(CHARSET=utf8 COLLATE utf8_bin),在mysql8后,在创建数据库时,字符集会设置utf8bm4,...

    详解JDBC对Mysql utf8mb4字符集的处理

    但是,这样还不够,我们还需要在Mysql配置文件my.cnf中指定字符集为utf8mb4。例如: [client] default-character-set = utf8mb4 [mysql] default-character-set = utf8mb4 [mysqld] character-set-client-handshake ...

    MySQL字符集utf8修改为utf8mb4的方法步骤

    - 在MySQL配置文件`my.cnf`中,你需要为`[client]`、`[mysqld]`和`[mysql]`部分设置`default-character-set=utf8mb4`。 - 同时,可以设置`collation-server = utf8mb4_unicode_ci`以确保排序规则。 - 另外,添加`...

    让MySql彻底支持中文_解决mysql数据库乱码

    对于中文支持,我们通常会选择`utf8`或`utf8mb4`字符集,因为它们包含了广泛的Unicode字符,包括简体和繁体中文。 步骤一:修改MySQL配置文件 在`my_我改好的.ini`这个文件中,很可能包含了MySQL的配置修改。你需要...

    MYSQL数据库使用UTF-8中文编码乱码的解决办法

    CREATE DATABASE `dbname` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci; ``` - 创建数据表时,对于存放中文的字段,同样需要设置为“utf8_general_ci”。例如,创建一个包含中文的`name`字段的表: ```...

    设置mysql字符集

    mysql> SET NAMES 'utf8mb4'; ``` 或者更详细的设置: ```sql mysql> SET character_set_client = utf8mb4; mysql> SET character_set_connection = utf8mb4; mysql> SET character_set_database = utf8mb4; mysql...

    mysql示例数据库(world)_解决中文乱码_使用UTF8字符集

    默认情况下,MySQL可能不直接支持中文字符,因此我们需要手动设置为支持中文的字符集,如UTF8或UTF8MB4。UTF8是一种通用的多字节字符编码,能够表示大部分世界上的字符,包括中文。 首先,你需要确保MySQL服务器...

    zh-cn-utf8

    3. **数据库连接**:在连接MySQL等数据库时,应设置字符集为`utf8mb4`,这是MySQL对UTF-8的扩展,支持四字节的Unicode字符,包括表情符号。 4. **HTML meta标签**:在HTML文档的`<head>`部分添加`<meta charset="...

    解决mysql乱码问题全解决

    - 考虑使用更广泛的字符集,如`utf8mb4`,它可以支持更多特殊字符。 - **问题三:部分旧数据无法正确转换** - 对于历史遗留数据,可能需要手动替换或修复。 - 可以编写脚本进行批量替换操作。 #### 五、结语 ...

    MySQL保存emoji表情

    解决这个问题的关键在于将MySQL的字符集由标准的UTF-8升级到UTF-8的扩展版本——UTF-8mb4。 #### 序言 随着移动互联网的发展,emoji表情成为了用户表达情感的重要方式之一。因此,在设计与无线互联网相关的MySQL...

Global site tag (gtag.js) - Google Analytics