django model实现,如何实现外键对多种模型,djangomodel,就是让ForeignMo
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
编橙之家文章,
相关内容
- Python闪退问题,py2exe打包执行闪退了怎么调整,pythonpy
- python不同版本list内中文输出问题,python不同版本,foo
- python函数应用请大神帮我看代码问题,python大神,问这个
- Django外键objects.get究竟该怎么写,djangoobjects.get,model定义
- 爬虫状态码返回状态200,自己访问400,这是什么原因?,爬
- Python requests爬虫编码encoding error是什么问题,requestsen
- 适合Python应用的Vim缩进调试方法,pythonvim缩进调试,我的
- python list列表append方法的性能问题,pythonappend,作为客户
- Python有没有开源包处理GBK Unicode编码问题,pythonunicode
- 了解python flask.Response(generator())流内容处理的朋友请进,
评论关闭