django多对多关联表的操作
2016-11-22 17:28
337 查看
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(
相关文章推荐
- 该文件没有程序与之关联来执行操作,请在控制面板的文件夹选项中创建关联的解决办法
- winform中树和数据库关联操作的例子(C#)
- 转帖:django中操作mysql
- 关于cxGrid选中行操作关联数据集的一种方法
- 计算机管理打不开,出现提示“该文件没有与之关联的程序来执行操作”
- 解决win7“该文件没有与之关联的程序来执行该操作”
- 转帖:django下操作数据库的字符问题
- Python手工加载Django的实际操作的四部分详解
- [Dynamic Language] Python Django: 基本操作
- 注册Windows文件类型和自动关联操作
- JQuery中Ajax跨域解决方案 关于ajax跨域操作的jquery, django实践 基于jquery的ajax之跨域解决方案
- 对关联表进行Update操作
- ImageHandler类负责图像处理的相关操作,如保存、图像关联操作等
- C#操作注册表建立文件关联
- 用完成端口关联文件操作
- RedHat 上安装多个 mysql 实例并配置 django 连接的操作记录
- 简化TD的操作——提交Bug时的默认值和关联值的设置
- ,“计算机”图标上面右键,选择“管理”选项时提示:“该文件没有与之关联的程序来执行该操作
- 访问FTP提示。该文件没有程序与之关联来执行操作
- ThinkPHP对于数据库的关联操作+实例(完美收藏)