mysql配置utf8_mb4

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

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

 

20180628补充数据库

我如今使用的是ucloud的云数据库,发如今控制台不管怎么set修改数据库的类型,表类型,字段类型都是不行的。windows

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

浪费了两个多小时。 编码

 

20180629补充.net

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

1.修改mysql的配置文件

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

[client]code

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表情的数据变成乱码。因此在本地导出的时候具体操做步骤以下:

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

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

5.2导入

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

相关文章
相关标签/搜索