django多对多关联表的操作

简介:

1.发生背景:在django项目中需要一个项目管理和一个资产管理。就牵涉到多对多的关系,如下:

class AssetGroup(models.Model):
   GROUP_TYPE = (
       ('P','PRIVATE'),
       ('A','ASSET')
   )
   name = models.CharField(max_length=80,unique=True)
   comment = models.CharField(max_length=300,blank=True,null=True)

   def __unicode__(self):
       return self.name
class Asset(models.Model):
   """
   定义资产信息
   """
   group = models.ManyToManyField(AssetGroup, blank=True, verbose_name=u"项目名")
   env = models.IntegerField(choices=ASSET_ENV, blank=True, null=True, verbose_name=u"运行环境")
   ip = models.CharField(max_length=32, blank=True, null=True, verbose_name=u"主机IP")
   other_ip = models.CharField(max_length=255, blank=True, null=True, verbose_name=u"联通ip或者云主机ip")
   system_version = models.CharField(max_length=8, blank=True, null=True, verbose_name=u"系统版本号")
   kernel_version = models.CharField(max_length=32,blank=True,null=True,verbose_name=u'内核版本信息')
   ssh_version = models.CharField(max_length=32,blank=True,null=True,verbose_name=u'ssh版本信息')
   status = models.IntegerField(choices=ASSET_STATUS, blank=True, null=True, default=1, verbose_name=u"机器状态")
   idc = models.ForeignKey(IDC, blank=True, null=True,  on_delete=models.SET_NULL, verbose_name=u'机房')
   cpu = models.CharField(max_length=64, blank=True, null=True, verbose_name=u'CPU')
   memory = models.CharField(max_length=128, blank=True, null=True, verbose_name=u'内存')
   disk = models.CharField(max_length=1024, blank=True, null=True, verbose_name=u'硬盘')
   date_added = models.DateTimeField(auto_now=True, null=True)
   comment = models.CharField(max_length=128, blank=True, null=True, verbose_name=u"备注")

2.具体操作:
当添加了资产和项目的时候,发现这2者并未产生关联,没有对关联表进行任何操作,所以需要对关联表进行操作进行关联
在视图里面的操作如下:
Group = AssetGroup.objects.filter(


本文转自 luoguo 51CTO博客,原文链接:http://blog.51cto.com/luoguoling/1875508

相关文章
|
3月前
|
关系型数据库 MySQL 数据库连接
使用Django框架完成用户的增删改查操作
使用Django框架完成用户的增删改查操作
36 1
|
6月前
|
SQL 关系型数据库 MySQL
Django入门ORM(Django操作MySQL) 专题一
Django入门ORM(Django操作MySQL) 专题一
|
1天前
|
Python
使用Django时,如何设计模型关系(一对一、一对多、多对多)?
Django支持三种模型关联:ForeignKey(一对多),OneToOneField(一对一)和ManyToManyField(多对多)。ForeignKey示例:`Article`有一个指向`Author`的外键。OneToOneField示例:`UserProfile`与`User`一对一关联。ManyToManyField示例:`Student`和`Course`之间多对多关系。这些关联字段便于反向查询,如`article.author`获取作者,`author.article_set.all()`获取作者所有文章。
7 1
|
1月前
|
SQL API 数据库
一篇文章带你了解Django ORM操作
一篇文章带你了解Django ORM操作
20 0
|
1月前
|
缓存 中间件 API
使用 Django 的异步特性提升 I/O 类操作的性能
使用 Django 的异步特性提升 I/O 类操作的性能
42 0
|
6月前
|
缓存 关系型数据库 MySQL
Django操作MySQL数据库的优化方法
Django操作MySQL数据库的优化方法
|
9月前
|
Python
【Django实战】创建多对多关系表的三种模式及优缺点分析
【Django实战】创建多对多关系表的三种模式及优缺点分析
|
4月前
|
人工智能 开发工具 数据库
Django实践-03模型-02基于admin管理表
Django实践-03模型-02基于admin管理表
Django实践-03模型-02基于admin管理表
|
4月前
|
关系型数据库 MySQL 数据库
Django实践-03模型-01表生成模型+学科页面与教师页面编写
Django实践-03模型-01表生成模型+学科页面与教师页面编写
Django实践-03模型-01表生成模型+学科页面与教师页面编写
|
6月前
|
分布式计算 数据挖掘 数据处理
Django操作Spark
Django操作Spark