Django+mysql支持emoji表情
来源:互联网 发布:js设置页面自动刷新 编辑:程序博客网 时间:2024/06/06 20:09
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、重启数据数
- Django+mysql支持emoji表情
- mysql 支持emoji表情
- mysql emoji表情支持
- Mysql支持emoji表情
- mysql支持emoji表情
- MySQL支持emoji表情
- Mysql支持Emoji表情
- 让Mysql支持Emoji表情
- 让Mysql支持Emoji表情
- Mysql 字符集,支持Emoji表情
- 让Mysql支持Emoji表情
- mysql支持存储emoji表情
- 让MySQL支持Emoji表情
- 让mysql支持emoji表情
- 让Mysql支持Emoji表情
- web支持emoji表情(mysql)
- 让MySQL支持emoji表情
- Mysql支持emoji表情存储
- Linux文件管理
- 洛谷 P3203 [HNOI2010]BOUNCE 弹飞绵羊(分块)
- 用MyEclipse10开发基于JAX-WS的Web Service实例,接口查询oracle数据库,SpringMVC controller调用接口,附带源码
- java.lang.OutOfMemoryError: Failed to allocate a 3110419 byte allocation with 741152 free bytes and
- 经典笔试题——去掉字符串中连续出现K个0的子串
- Django+mysql支持emoji表情
- spring mvc项目的jsp找不到 静态CSS,JS加载js 404错误
- 异常According to TLD or attribute directive in tag file)的处理
- 欢迎使用CSDN-markdown编辑器
- 详解:mybatis的缓存机制(一级缓存二级缓存和刷新缓存)和mybatis整合ehcache
- Python 操作sqlite数据库
- linux free命令中buffer和cache的区别
- Linux centos7第一次启动时无图形界面安装
- Linux下的五种I/O模型