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
4、重启数据数