如果有办法更好地说出这个问题的标题,请告诉我。
在django中,我试图创建这种模型层次结构:
User
-Author [Author model]
--Sentence [Sentence model]
--Find_Replace [FindReplace model]
用户将多位作者设置为"笔名"。作者有自己的句子,以及他自己的预定义查找/替换集。句子可以与多个查找/替换集相关联,但仅与该作者创建的句子相关联。
我难以理解的是:你是如何建立这种关系的?
这就是我所拥有的 - 如果没有程序化的修改,我对于严格定义这些关系的好方法感到茫然。
以下是目前为止的模型,只是部分正确:
class Author(models.Model):
created_by = models.ForeignKey(User)
class FindReplace(models.Model):
created_by = models.ForeignKey(User)
author = models.ForeignKey(Author)
find = models.CharField(max_length=256)
replace = models.CharField(max_length=5000)
class Sentence(models.Model):
created_by = models.ForeignKey(User)
account = models.ForeignKey(Account)
text = models.CharField(
max_length=500,
blank=False,
null=False,
)
答案 0 :(得分:1)
我不明白为什么你会在每个模型中都需要WebView
字段,因为它们与created_by
相关,因此与Author
相关。我建议使用这样的:
User
关于严格维护规则,您无法在模型结构中定义规则。您可以使用model validation或Modelform validation或在以下模型中编写自己的函数:(例如)
class Author(models.Model):
created_by = models.ForeignKey(User)
class FindReplace(models.Model):
author = models.ForeignKey(Author)
find = models.CharField(max_length=256)
replace = models.CharField(max_length=5000)
class Sentence(models.Model):
account = models.ForeignKey(Account) #Is account related to user? The you can query it by user.
# Or add an FK relation to Author.
text = models.CharField(
max_length=500,
blank=False,
null=False,
)
使用方法: 在views.py中:
class FindReplace(models.Model):
author = models.ForeignKey(Author)
find = models.CharField(max_length=256)
replace = models.CharField(max_length=5000)
def _validate_creation(self, user_id):
if self.author.created_by.id == user_id:
return True
else:
return False
答案 1 :(得分:0)
为什么需要作者模型?作者=用户,django将自动为您创建关系
答案 2 :(得分:0)
以下是我们使用外键的模型:
class Department(models.Model):
dept_id = models.CharField(primary_key=True,max_length=20,unique=True)
dept_name = models.CharField(max_length=20)
dept_add = models.CharField(max_length=30)
def _str_(self):
return "%s,%s" % (self.dept_id, self.dept_name)
class Emp_Department(models.Model):
emp_no = models.ForeignKey(Employee)
dept_id = models.ForeignKey(Department)
emp_type = models.CharField(max_length=30)
desi_id = models.CharField(max_length=30)
join_date = models.DateField()
retire_date = models.DateField()