摘要:MySQL数据库入门中,我们知道项目开发过程时,需要支持发送表情,且原来mysql数据库字符集并没有很好地同意,顺便也一把统一成utf8mb4。希望对大家学习MySQL数据库入门有所帮助。
MySQL数据库入门中,我们知道项目开发过程时,需要支持发送表情,且原来mysql数据库字符集并没有很好地同意,顺便也一把统一成utf8mb4。希望对大家学习MySQL数据库入门有所帮助。
查看字符集命令
全系统
show variables like 'char%';
单表
show create table tabname;
过程
1.关闭服务器
2.导出数据库表结构及记录
mysqldump -uroot -p --default-character-set=utf8mb4 -d database > createdb.sql
mysqldump -uroot -p --no-create-info database > datadb.sql
3.修改编码
因为原来数据库中还有latin1的表,所以先转成utf8,在转成utf8mb4,也可以一把转成utf8mb4,这个过程随意。
sed -i s/CHARSET=latin1/CHARSET=utf8/g `grep -rl "CHARSET=latin1" createdb.sql`
sed -i s/CHARSET=utf8/CHARSET=utf8mb4/g `grep -rl "CHARSET=utf8" createdb.sql`
sed -i s/CHARSET=latin1/CHARSET=utf8/g `grep -rl "CHARSET=latin1" datadb.sql`
sed -i s/CHARSET=utf8/CHARSET=utf8mb4/g `grep -rl "CHARSET=utf8" datadb.sql`
4.修改varchar(2084)为varchar(1024)
在创建表的过程中发现原来有些表的字段设置过长,报了一个ERROR 1118 (42000): Row size too large. The maximum row size for the used table type, not counting BLOBs, is 65535.
You have to change some columns to TEXT or BLOBs。的错误。查了一下utf8mb4是四个字节表示一个字符,2048*4>65535,单行过长,幸好查看了数据库没有很长的记录,所以就把varchar(2048)改成varchar(1024)
sed -i s/"varchar(2048)"/"varchar(1024)"/g `grep -rl "varchar(2048)" createdb.sql`
5.创建新表
加上默认字符集
create database newdb default charset utf8mb4;
6.导入表及记录
mysql -uroot -p doctorz < createdb.sql
mysql -uroot -p doctorz < datadb.sql
7.修改/etc/my.cnf,增加:
[client]
default-character-set=utf8mb4
[mysql]
default-character-set=utf8mb4
[mysqld]
character-set-client-handshake = FALSE
character-set-server=utf8mb4
init-connect='SET NAMES utf8mb4'
wait_timeout=2147483
8.修改项目中连接数据库的方式
9.重启数据库
service mysqld restart
10.启动服务
本文由职坐标整理并发布,了解更多内容,请关注职坐标数据库MySQL数据库频道!
您输入的评论内容中包含违禁敏感词
我知道了
请输入正确的手机号码
请输入正确的验证码
您今天的短信下发次数太多了,明天再试试吧!
我们会在第一时间安排职业规划师联系您!
您也可以联系我们的职业规划师咨询:
版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
沪公网安备 31011502005948号