Django+mysql支持emoji表情
2017-08-09 17:13
393 查看
mysql开始使用的是utf-8编码,使用微信进行第三方登录后,同步微信昵称是报错:
OperationalError: (1366, "Incorrect string value: '\\xF0\\x9F\\x90\\xA0' for column 'nickname' at row 1")
经过排查发现该微信号的昵称里包含emoji表情,emoji表情对应的编码是4个字节, 而utf-8是3个字节,所以报错。
解决方法:
1、修改django连接数据库时的字符集
在django项目的setting文件中,你必须设置charset=utf8mb4
DATABASES = {
'default': {
'OPTIONS': {'charset': 'utf8mb4'},
}
}
2、修改数据库,表,列的字符集
ALTER DATABASE database_name CHARACTER SET = utf8mb4 COLLATE utf8mb4_unicode_ci;
ALTER TABLE user CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
报错:MySQL: ERROR 1071 (42000): Specified key was too long; max key length is 767 bytes
原因:mysql的索引是有长度限制的, 我的表里有个索引字段的长度是255。 255*4 = 1020, 大于767。mysql索引长度限制请参考链接:点击打开链接
ALTER TABLE user CHANGE nickname nickname varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL;
3、修改sql_mod
设置mysql
sql_mod
4、重启数据数
OperationalError: (1366, "Incorrect string value: '\\xF0\\x9F\\x90\\xA0' for column 'nickname' at row 1")
经过排查发现该微信号的昵称里包含emoji表情,emoji表情对应的编码是4个字节, 而utf-8是3个字节,所以报错。
解决方法:
1、修改django连接数据库时的字符集
在django项目的setting文件中,你必须设置charset=utf8mb4
DATABASES = {
'default': {
'OPTIONS': {'charset': 'utf8mb4'},
}
}
2、修改数据库,表,列的字符集
ALTER DATABASE database_name CHARACTER SET = utf8mb4 COLLATE utf8mb4_unicode_ci;
ALTER TABLE user CONVERT TO CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
报错:MySQL: ERROR 1071 (42000): Specified key was too long; max key length is 767 bytes
原因:mysql的索引是有长度限制的, 我的表里有个索引字段的长度是255。 255*4 = 1020, 大于767。mysql索引长度限制请参考链接:点击打开链接
ALTER TABLE user CHANGE nickname nickname varchar(100) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL;
3、修改sql_mod
设置mysql
sql_mod
4、重启数据数
相关文章推荐
- MySQL支持emoji表情的存储
- Java、mysql支持emoji表情
- 让MySql支持Emoji表情
- 让MySQL支持emoji表情
- 让Mysql支持Emoji表情
- Python3和Django如何支持MySQL和MariaDB数据库
- mysql支持emoji表情
- django及mysql中文支持相关
- IOS mysql/Java服务端对emoji表情的支持
- 让MySQL支持Emoji表情
- mysql支持emoji表情的方法
- 让MySql支持Emoji表情(MySQL中4字节utf8字符保存方法)
- mysql5.5 版本以上utf8 支持 emoji表情
- django 文件上传和菜单分级,mysql支持事务,F模块自增字段, python发送get,post请求
- MySQL中支持emoji表情的存储
- MySQL中支持emoji表情的存储
- Python3 + django 支持 MySQL
- web支持emoji表情(mysql)
- MySQL编码修改--> 支持emoji表情
- MySQL的BLOB类型(解决mysql不支持mb4编码的时候存储emoji表情问题)