您的位置:首页 > 产品设计 > UI/UE

7.24-7.26 JLL实习日志-Django UI Modification

2017-07-28 16:44 447 查看
ManyToMany 模型

数据模型如下 ,Brand 在 model中 定义 了 一个
Company_Group
属性 ,显性显示 了对应 的 company的 组群 ,Company 模型 中 隐形定义了关系

class Brand(models.Model):
Company_Group = models.ManyToManyField(Company)
Brand_Group = models.CharField(u'Brand Group',max_length=255, default="")


class Company(models.Model):
Pref_Company_Name_Flg = models.CharField(u'Preferred Name Flag',max_length=255, default="")
Pref_Company_Name = models.CharField(u'Preferred Name',max_length=255, default="")
Company_Type = models.CharField(u'Company Type',max_length=255, default="")
Company_Name = models.CharField(u'Company Name',max_length=255, default="")


View 端 分为 两种 方式,由 Brand_id得到 所在 的 company_group ,或者 是 由 company_id 得到 Brand_group 两种 方式

第一种 方式 ,
Company_Group
可以 直接使用 ,有对应 的 针对
company_instance
对象 DESC的操作,显示
Company_Group
的 id需要 使用
Company_Group__id
的 方式 ,里面 有 两种 过滤 方式
__exact
表示 精确匹配 ,
__icontains
表示 的 是 模糊 匹配,

instance_id = request.GET.get('company_id')
company_instance=get_object_or_404(Company,pk=int(instance_id))            brand_instance.Company_Group.add(company_instance)
brand_instance.Company_Group.remove(company_instance)
brand_instance.save()


第二种 方式
_set.all()
的方式 ,得到
Brand_instance
的对象 ,隐式 得到 显示 的 方式 ,因为 Company没有 类似
brand_group


company_instance = Company.objects.get(id=company_id)
brand_instances=company_instance.brand_set.all()


第三种表示的 使用 过滤的 形式,注意 在 ORM 中
Brand
Company
模型 没有 明确 定义
id
的 属性 ,使用
__id
的 方式 拿到

###############################
brand_instances= Brand.objects.filter(Company_Group__id__exact=company_instance.id)
##############################
conversations=Conversation_Brand.objects.filter(Brand__id__icontains =id_list).order_by('-Created_On')
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: