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_mb4相关推荐

  1. centos7给MySQL配置环境变量

    centos7给MySQL配置环境变量 配置好了环境变量,就可以不用每次想要使用mysql时都要到/usr/local/mysql/bin,所以需要配置以下环境变量 编辑配置文件,加入环境变量 Vi ...

  2. 在Server 2003上部署IIS+PHP+MySQL配置清单

    在Server 2003上部署IIS+PHP+MySQL I.安装Windows Server 2003 将光盘放入光驱中,设置BIOS,从CDROM引导加载安装程序,等待启动: 设置注册信息,名字和 ...

  3. docker mysql配置 丢失_Docker 从入门到掉坑

    Docker 介绍 简单的对docker进行介绍,可以把它理解为一个应用程序执行的容器.但是docker本身和虚拟机还是有较为明显的出入的.我大致归纳了一下,可以总结为以下几点: docker自身也有 ...

  4. 这些MySQL配置“修改条令”,你有必要熟识默记!

    大多数开发者可能不太会关注MySQL的配置,毕竟在基本配置没有问题的情况下,把更多的精力放在schema设计.索引优化和SQL优化上,是非常务实的策略.这时,如果再花力气去优化配置项,获得的收益通常都 ...

  5. Centos 6.4下 MySQL配置主从服务(集群)

    Centos 6.4下 MySQL配置主从服务(集群) 我们前面两篇文章都分别介绍了Mysql的安装及配置.备份及还原,今天我们继续前面的环境介绍一下Centos 6.4下MySQL配置主从实现数据同 ...

  6. mysql配置参数调优(8GB内存和64GB内存)

    文章目录 一.前言 二.查看服务器的CPU和内存 1.查看CPU的个数 2.查看服务器的内存 3.数据库版本 三.64GB内存的mysql配置参数 四.本机8GB内存的mysql配置参数 1.查看数据 ...

  7. SpringMVC+Mybatis+MySQL配置Redis缓存

    SpringMVC+Mybatis+MySQL配置Redis缓存 1.准备环境: SpringMVC:spring-framework-4.3.5.RELEASE-dist Mybatis:3.4.2 ...

  8. php django mysql配置文件_Mysql学习Django+mysql配置与简单操作数据库实例代码

    <Mysql学习Django+mysql配置与简单操作数据库实例代码>要点: 本文介绍了Mysql学习Django+mysql配置与简单操作数据库实例代码,希望对您有用.如果有疑问,可以联 ...

  9. zabbix mysql监控告警_Zabbix监控mysql配置及故障告警配置

    同时介绍了触发器的创建及zabbix通过邮件方式告警配置. 一.配置自带模板监控mysql 1.提供配置文件模板 文件位置在源码包/usr/local/src/zabbix-3.0.4/conf/za ...

最新文章

  1. 【Android 内存优化】使用 Memory Analyzer ( MAT ) 工具分析内存 ( MAT 工具使用 | 最大对象 | 类实例个数 | 引用与被引用 | GC Roots 最短链 )
  2. 请求模式解决共享资源冲突
  3. 一次ctf中代码审计分析
  4. 2.数据湖DeltaLake之DDL操作
  5. java list拷贝_深入了解浅拷贝与深拷贝
  6. Java 3 年,25K 多吗?
  7. 关于SQL数据字典的详解
  8. 计算机毕业设计Java宠物医院管理系统(源码+系统+mysql数据库+lw文档)
  9. codeblocks下载安装教程(完整详细)
  10. Java聊天室系统的设计与实现(完整源码 sql文件 论文)
  11. java 堆栈大小设置_如何增加Java堆栈大小?
  12. Qt 字体大小的计算
  13. 高通平台msm8916修改开机logo 高通平台修改LK(bootloader)开机logo
  14. python——正则表达式(re模块)详解
  15. PDF不能打印和复制的问题如何解决?
  16. AS:另一个程序正在使用此文件,进程无法访问。
  17. python发post请求json_python request 以json形式发送post请求的正确的姿势
  18. Linux下 网卡测速
  19. Python 去掉空格的方法
  20. Mac 下安装 go

热门文章

  1. vue封装echarts示例
  2. python指定返回类型_如何在python中指定方法返回类型列表 - python
  3. python多线程queue_python多线程+队列(提高爬虫时效性)
  4. linux克隆后没有eth0,解决linux机器克隆后eth0不见的问题
  5. python迭代计算pi_python使用三角迭代计算圆周率PI的方法
  6. gdb 调试_一文入门Linux下gdb调试(二)
  7. php中的echo单引号_PHP 邮件漏洞小结
  8. win10 mfc 连接mysql_win10下使用c语言连接mysql
  9. 苹果CMS V10 播放记录_苹果cms采集后无法播放怎么解决?
  10. python html模板_Tempy-纯Python语法的HTML模板库