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