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(

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章