您的位置:首页 > 数据库 > SQL

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、重启数据数
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  django mysql emoji