2010-06-26 4 views
2

확장 사용자 프로필에 대해 일부 장고 모델이 있습니다. 문제는이 코드가 syncdb가 사용될 때 테이블을 생성하지 않는다는 것입니다 (아무 일도 일어나지 않습니다. 유효성 검사 오류 없음). 왜 그런 일이 일어나는거야? (또한 그 모델은 다른 곳에서 가져 오기 오류를 줄) :모델이 동기화 될 때 테이블을 만들지 않습니다.

#!/usr/bin/env python 
# encoding: utf-8 
from django.db import models 
from django.contrib.auth.models import User 
from registration.signals import user_registered 
from forms import ExtendedRegistrationForm 
import hashlib 

class InheritedProfile(models.Model): 
    first_name = models.CharField("Name", max_length=50, blank=True, null=True) 
    last_name = models.CharField("Last name", max_length=50, blank=True, null=True) 
    pid = models.CharField("PESEL", max_length=11, blank=True, null=True) 
    street = models.CharField("Street", max_length=50, blank=True, null=True) 
    number = models.CharField("Flat/house number", max_length=10, blank=True, null=True) 
    code = models.CharField("Zip ", max_length=6, blank=True, null=True) 
    city = models.CharField("City", max_length=50, blank=True, null=True) 
    class Meta: 
     abstract=True 

class UserProfile(InheritedProfile): 
    def upload_path(self, field_attname): 
     filename = hashlib.md5(field_attname).hexdigest()[:4] + "_" + field_attname 
     return "uploads/users/%s" % (filename,) 

    user = models.ForeignKey(User, unique=True, related_name='profile') 
    image = models.ImageField(upload_to=upload_path, verbose_name="Image", blank=True, null=True) 

    class Meta: 
     ordering = ['-id'] 
     db_table = 'userprofile' 

    def __unicode__(self): 
     return u"%s " % self.user.username 

def user_created(sender, user, request, **kwargs): 
    form = ExtendedRegistrationForm(request.POST) 
    extended_user = UserProfile(user=user) 
    extended_user.is_active = False 
    extended_user.first_name = form.cleaned_data['first_name'] 
    extended_user.last_name = form.cleaned_data['last_name'] 
    extended_user.pid = form.cleaned_data['pid'] 
    extended_user.image = form.cleaned_data['image'] 
    extended_user.street = form.cleaned_data['street'] 
    extended_user.number = form.cleaned_data['number'] 
    extended_user.code = form.cleaned_data['code'] 
    extended_user.city = form.cleaned_data['city'] 
    extended_user.save() 

user_registered.connect(user_created) 

class Friend(InheritedProfile): 
    friend_of = models.ForeignKey(UserProfile, related_name='friend_of') 
    class Meta: 
     db_table = 'friend' 

반면에이 코드를 완벽하게 테이블을 생성합니다

#!/usr/bin/env python 
# encoding: utf-8 
from django.db import models 
from django.contrib.auth.models import User 
import hashlib 

class InheritedProfile(models.Model): 
    first_name = models.CharField("Name", max_length=50, blank=True, null=True) 
    last_name = models.CharField("Last name", max_length=50, blank=True, null=True) 
    pid = models.CharField("PESEL", max_length=11, blank=True, null=True) 
    street = models.CharField("Street", max_length=50, blank=True, null=True) 
    number = models.CharField("Flat/house number", max_length=10, blank=True, null=True) 
    code = models.CharField("Zip ", max_length=6, blank=True, null=True) 
    city = models.CharField("City", max_length=50, blank=True, null=True) 
    class Meta: 
     abstract=True 

class UserProfile(InheritedProfile): 
    def upload_path(self, field_attname): 
     filename = hashlib.md5(field_attname).hexdigest()[:4] + "_" + field_attname 
     return "uploads/users/%s" % (filename,) 

    user = models.ForeignKey(User, unique=True, related_name='profile') 
    image = models.ImageField(upload_to=upload_path, verbose_name="Image", blank=True, null=True) 

    class Meta: 
     ordering = ['-id'] 
     db_table = 'userprofile' 

    def __unicode__(self): 
     return u"%s " % self.user.username 

class Friend(InheritedProfile): 
    friend_of = models.ForeignKey(UserProfile, related_name='friend_of') 
    class Meta: 
     db_table = 'friend' 

내가 다른 곳이 user_created 기능을 이동해야 하는가? 신호가 여기에 문제를 일으켜서는 안됩니다 ...

+0

'forms'에서 아마도'models' 또는 특정 모델을 가져올 수 있습니까? –

+0

특정 모델을 가져오고 있습니다. 왜이 기능이 모델 테이블 생성과 충돌했는지는 모르겠지만 다른 파일로 옮겼습니다. 이제 모든 것이 작동합니다. – crivateos

답변

3

글쎄, 당신은 어떤 종류의 교차 수입을 가지고있는 것 같습니다; 일부 모델을 forms으로 가져오고 거기에서 어떤 양식을 다시 models으로 가져 오면 modelsforms을 가져와야하고 formsmodels이 다시 필요하기 때문에 해결할 수 없습니다. 해결할 수 없습니다.

이 외에도 뷰와 더 관련이 있기 때문에 모델 모듈에서 폼을 가져올 필요가없는 더 나은 디자인이라고 생각합니다!

+1

순환 수입은 완벽하게 문제를 해결합니다. 모듈 내의 속성 조회는 가능하지 않을 수 있습니다. http://stackoverflow.com/questions/3082015/python-module-initialization-order/3082097#3082097 –

관련 문제