我的django.contrib.auth用户模型存在问题,其中电子邮件max_length为75.
我从facebook api收到超过75个字符的电子邮件地址,我需要(非常愿意)将它们存储在用户中,以确保来自facebook connect和其他用户的用户之间的连续性。
我能够通过手动编辑mySql数据库中的字段来解决“Data truncated for column 'email' at row 1
”的问题,但有更好的解决方法吗?最好是< strong>不涉及我手动编辑数据库每次我重置它以进行架构更改?
我可以编辑数据库,只要我可以将它添加到重置脚本或initial_data.json文件中。
答案 0 :(得分:12)
电子邮件地址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中
答案 1 :(得分:2)
现在有一张增加Django电子邮件字段长度的票证:http://code.djangoproject.com/ticket/11579