我的django.contrib.auth用户模型存在问题,其中电子邮件max_length为75.
我从facebook api收到超过75个字符的电子邮件地址,我需要(非常愿意)将它们存储在用户中,以确保来自facebook connect和其他用户的用户之间的连续性.
我能够Data truncated for column 'email' at row 1
通过手动编辑mySql数据库中的字段来解决" " 的问题,但有没有更好的方法来解决这个问题?最好是每次重置模式更改时都不涉及我手动编辑数据库的那个?
我可以编辑数据库,只要我可以将它添加到重置脚本或initial_data.json文件中.
EmailField 75字符长度在django中是硬编码的.你可以解决这个问题:
from django.db.models.fields import EmailField def email_field_init(self, *args, **kwargs): kwargs['max_length'] = kwargs.get('max_length', 200) CharField.__init__(self, *args, **kwargs) EmailField.__init__ = email_field_init
但这会改变所有EmailField字段的长度,所以你也可以尝试:
from django.contrib.auth.models import User from django.utils.translation import ugettext as _ from django.db import models User.email = models.EmailField(_('e-mail address'), blank=True, max_length=200)
两种方式最好将此代码放在INSTALLED_APPS中的django.contrib.auth之前的任何模块的init中