父母模型专属的多对多关系子女。怎么样?

时间:2015-06-13 01:37:59

标签: python django models

如果有办法更好地说出这个问题的标题,请告诉我。

在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, 
        )

3 个答案:

答案 0 :(得分:1)

我不明白为什么你会在每个模型中都需要WebView字段,因为它们与created_by相关,因此与Author相关。我建议使用这样的:

User

关于严格维护规则,您无法在模型结构中定义规则。您可以使用model validationModelform 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()