转: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
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中的导出)
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文件的物理路径,来进行如下的导入。
相关推荐
版本:mysql5.7 环境:windows 备注:配置mysql的字符集为utf8mb4 *为了解决mysql乱码参考了几个博客,只能在此鸣谢一下所有提供有价值的博客作者,此文件就上传备份一下
主要介绍了Spring Data Jpa Mysql使用utf8mb4编码的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
1. mysqlbinlog: [ERROR] unknown variable ‘default-character-set=utf8mb4’ 当我们在my.cnf中添加default-character-set=utf8mb4选项,那么在mysqlbinlog查看binlog时就会报错。 解决方案:.mysqlbinlog 后面...
# 服务端使用的字符集默认为utf8mb4 character-set-server=utf8mb4 # 创建新表时将使用的默认存储引擎 default-storage-engine=INNODB # 默认使用“mysql_native_password”插件认证 #mysql_native_password default...
字符集为utf8 -- UTF-8 Unicode(为了节省空间,我不打算为了emoji而使用utf8mb4) 排序规则为utf8_general_ci(意为:不区分大小写,这样比较快) 接着在pet_forge数据库下,运行本项目中数据库备份文件夹下的pet_forge...
2,更改网站编码编码为uft8,采集GBK自动转为utf8,创建数据库编码为utf8mb4,把sql目录下的jieqi2.4.sql导入数据库,作为网站的初始数据库结构和数据,更改为存储为INNODB 3,上传网站程序后,以下4个目录必须可...
mysql> CREATE DATABASE demo_django_supermarket DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; ``` - 检查数据库默认编码 ```mysql mysql> USE demo_django_supermarket; mysql> SELECT @@...
CREATE DATABASE IF NOT EXISTS spring_kafka_example CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci; 确保数据库连接正确后,由于项目使用了 Liquibase 进行数据库初始化和更新,所以只需要启动项目即可自动...
PHP版本必须大于等与5.4 Mysql必须支持INNODB引擎,数据库默认编码请指定为utf8mb4,集合为utf8mb4_unicode_ci,创建语句如下 CREATE DATABASE `database_name` /*!40100 DEFAULT CHARACTER SET utf8mb4 COLLATE ...
MySQL Windows自动安装批处理文件。功能如下: 1. 设置密码 2. 设置环境变量 3. 设置编码为utf8mb4 4. 设置远程连接端口 5. 创建mysql配置文件 6. 环境变量立刻生效
mysql 8.0.13安装配置方法分享给大家,希望对你有帮助。 1、下载mysql-8.0.13安装包 下载地址,选择zip安装包下载就好。 2、解压到你要安装的目录 ...character-set-server = utf8mb4 #默认存储引擎 default-stora
MYSQL_CHARSET=utf8mb4 # REDIS链接 REDIS=true REDIS_HOST=127.0.0.1 REDIS_PORT=6379 REDIS_PREFIX=xxx # 七牛云 QINIU=false QINIU_ACCESSKEY=xxx QINIU_SECRETKEY=xxx QINIU_BUCKET=xxx QINIU_DOMAIN=xxx # ...
安装了个5.5版本的mysql,字符集出现了问题,之前的mysql服务器都是通过在my.cnf配置文件中进行配置便可,可是今儿怎么着都不行一直报错: 当时系统中也没有配置错误日志,所以只能是先配置下错误日志的位置,看看...
本文记录了mysql 8.0.15 安装配置的方法,供大家参考,具体内容如下 安装包下载 链接: MySQL官网下载地址 点第一个Download,第一个和第二个安装包的区别在于,第一...default-character-set = UTF8MB4 [mysqld] por
在 Rails 在迁移、模式等中添加对 UTF8MB4 的支持之前,这是一种解决方法。安装将此行添加到应用程序的 Gemfile 中: gem 'demoji'然后执行: $ bundle或者自己安装: $ gem install demoji用法在config/...
SET NAMES utf8mb4; SET FOREIGN_KEY_CHECKS = 0; -- ---------------------------- -- Table structure for account -- ---------------------------- DROP TABLE IF EXISTS `account`; CREATE TABLE `...
奥兰治学校基于Node.js + MySQL开发的开源微信小程序商城二次开发(微信小程序)初期API开发环境配置创建数据库nideshop并导入项目根目录下的nideshop.sql CREATE SCHEMA `nideshop` DEFAULT CHARACTER SET utf8mb4 ...
【资源说明】 1、该资源包括项目的全部源码,... '--collation-server=utf8mb4_unicode_ci' ] redis: image: redis:latest container_name: redis command: redis-server /etc/redis/redis.conf privileged: tr
在数据库中建立一个名为audio-visual的数据库,数据库的字符集选择为utf8mb4,排列规则选择为utf8mb4_general_ci ,并且运行audio-visual.sql文件,导入数据表2.在audio-visual-server中的application.yml配置mysql...
通过show variables like 'character_set%%';... character_server_set=utf8 [mysql] default-character-set=utf8 [mysql.server] default-character-set=utf8 [mysql_safe] default-character-se