gpt4 book ai didi

database - 模型在同步时不创建表

转载 作者:搜寻专家 更新时间:2023-10-30 20:21:46 26 4
gpt4 key购买 nike

我有一些 Django 模型用于我的扩展用户配置文件。问题是当使用 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 函数移到别处吗?信号不应该在这里产生问题...

最佳答案

好吧,你似乎有某种交叉导入;如果您将一些模型导入 forms 并将某些模型从那里导入回 models 这无法解决,因为在处理 models 需要导入formsforms又需要models……这个无法解决!

除此之外,我认为不需要在模型模块中导入表单是更好的设计,因为它们与 View 更相关!

关于database - 模型在同步时不创建表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3124052/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com