django model实现,如何实现外键对多种模型,djangomodel,就是让ForeignMo


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

首先题主用的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)

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

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

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

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

class User(models.Model):    passclass 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

编橙之家文章,

评论关闭