models_多对多创建

一、多对多Models.py创建

关系说明:
cm_host:存放主机信息
cm_application:存放应有信息
cm_hostapp:将两个表的信息关联起来
第一种创建使用models.ForeignKey可以用于多个表

class HOST(models.Model):
    uid = models.AutoField(primary_key=True)
    host = models.CharField(max_length=32,db_index=True)
    ip = models.GenericIPAddressField(max_length=32,db_index=True)
    port = models.IntegerField()
    b = models.ForeignKey('Business',to_field = 'id')


class Application(models.Model):
    name = models.CharField(max_length=32)

class HostToApp(models.Model):
    hobj = models.ForeignKey('HOST',to_field='uid')
    aobj = models.ForeignKey('Application', to_field='id')

如图:


models_多对多创建_第1张图片
cm_host.png
models_多对多创建_第2张图片
cm_application.png
cm_hostapp.png

第二种创建models.ManyToManyFlied只能用于两个表

class HOST(models.Model):
    uid = models.AutoField(primary_key=True)
    host = models.CharField(max_length=32,db_index=True)
    ip = models.GenericIPAddressField(max_length=32,db_index=True)
    port = models.IntegerField()
    b = models.ForeignKey('Business',to_field = 'id')

#在其中一个已知表中,生成一个连接表名当前类名_属性名
#Application_r
class Application(models.Model):
    name = models.CharField(max_length=32)
    r = models.ManyToManyField('HOST')

创建的表:


models_多对多创建_第3张图片
创建的表名Application_r.png

二、操作表

用上面的第二种方法创建的表,由于不存在类去操作,无法直接对第三张表进行操作,可以通过Application.object.get()
(1)、展示
models.py知识点

1.因为将关联表的桥写在application 类中
2.因此可以吧‘桥’ 看做是applicaton类中的一部分
3.下面代码中i.name是这个表中原本包含的字段
4.i.r.all()是 r = models.ManyToManyField('HOST') 是链接类host对象
obj = models.Application.objects.all()
       for i in obj:
           print(i.name,i.r.all())

models.py展示

#多表展示
def app(request):
    if request.method == 'GET':
        #因为将关联表的桥写在application 类中
        #因此可以吧‘桥’ 看做是applicaton类中的一部分
        obj = models.Application.objects.all()
        return  render(request,'app.html',{'obj': obj})

html知识点

从后台返回的数据i.r.all包含了HOST对象,所以再次循环出里面的字段
{% for i in i.r.all %}
    {{ i.ip }}
{% endfor %}

html展示


    {% for i in obj %}
        
    {% endfor %}
应用列表 主机名称
{{ i.name }} {% for i in i.r.all %} {{ i.ip }} {% endfor %}
models_多对多创建_第4张图片
网页展示效果.png

(2)添加
form表单的添加
models.py

    elif request.method == 'POST':
        app_name = request.POST.get('app_name')
        host_id = request.POST.getlist('host_id')
        #调出桥所在的类中,一次对应增加host列对应关系
        obj = models.Application.objects.create(name=app_name)
        obj.r.add(*host_id)
        return redirect("/a/app")

html



models_多对多创建_第5张图片
image.png

你可能感兴趣的:(models_多对多创建)