首页 > django model里怎么实现外键对多种model

django model里怎么实现外键对多种model

就是让ForeignModel里的model不止一种,貌似choice不行


不太明白题主的问题?难道是只一个model下面的某个字段的外键是另外两个不同的model?想要下面的效果:

class User(models.Model):
    pass
class Author(models.Model):
    pass
class Book(models.Moldel):
    name = models.ForeignModel(User, Author) 

name = models.ForeignModel(User, Author)这样的写法是错的, ForeignModel 的参数没有这样设定的,而且这样的设计,好奇怪。

如果是同一个model的不同字段的外键指向同一个model,那么需要设置 related_name
伪代码大概如下:

class User(models.Model):
    pass

class Book(models.Model):  

    name = models.ForeignKey(User, related_name='name_user')  
    author = models.ForeignKey(User, related_name='author_user')  

关于 ForeignKey的参数 可以参考在这个 :http://blog.csdn.net/real_ray/article/details/18042693


首先题主用的Django版本是什么,django貌似没见过ForeignModel,根据orm,ForeignKey实际上就是sql里面的外键,个人理解楼主的题目是能不能一个字段对应多个其他表,如下:

class WhatAreYouTryToAsk:
    filed_XXX = models.ForeignKey((ModelA,ModelB,))  

这是不科学的啊亲,对于sql来说也不会一个字段能对应多个外键,想实现这种效果只能是有一张ModelA,ModelB的中间表,而filed的外键对应这张中间表

class MiddleTable(models.Model):
    model_a =  models.ForeignKey(ModelA)  
    model_b =  models.ForeignKey(ModelB) 

class WhatAreYouTryToAsk:
    filed_XXX = models.ForeignKey(MiddleTable) 

简单的说就是ModelA和ModelB有一个多对多的关系,上面的方法是显示的指明一个MiddleTable表,实时上可以使用Django里面的ManyToMany,ManyToMany的实际上会建一张中间表,因此你可以在ModelA或ModelB建立一个ManyToMany的字段,具体ManyToMany的用法请查阅文档。

class ModelA(models.Model):
    model_bs = ManyToMany(ModelB)

class WhatAreYouTryToAsk:
    filed_XXX = models.ForeignKey(ModelA)
    # or this, 具体实现看需求
    # filed_XXX = models.ForeignKey(ModelB)
【热门文章】
【热门文章】