玩蛇网提供最新Python编程技术信息以及Python资源下载!
django网站项目展示大全

django model实现,如何实现外键对多种模型

就是让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):
    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

玩蛇网文章,转载请注明出处和文章网址:https://www.iplaypy.com/wenda/wd19741.html

相关文章 Recommend

玩蛇网Python互助QQ群,欢迎加入-->: 106381465 玩蛇网Python新手群
修订日期:2017年05月24日 - 14时24分23秒 发布自玩蛇网

您现在的位置: 玩蛇网首页 > Python问题解答 > 正文内容
我要分享到:

必知PYTHON教程 Must Know PYTHON Tutorials

必知PYTHON模块 Must Know PYTHON Modules