一、多对多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.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')
创建的表:
二、操作表
用上面的第二种方法创建的表,由于不存在类去操作,无法直接对第三张表进行操作,可以通过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 %}
<span style="background-color: chocolate">{{ i.ip }}</span>
{% endfor %}
html展示
<table border="1px" >
<tr>
<td>应用列表</td>
<td>主机名称</td>
</tr>
{% for i in obj %}
<tr>
<td>{{ i.name }}</td>
<td>
{% for i in i.r.all %}
<span style="background-color: chocolate">{{ i.ip }}</span>
{% endfor %}
</td>
</tr>
{% endfor %}
</table>
(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
<form action="{{ request.path_info }}" method="post">
<input name="app_name" placeholder="应用名称"><br>
<select host="sel" multiple name="host_id" >
{% for i in obj_ip %}
<option value="{{ i.uid }}">{{ i.ip }}</option>
{% endfor %}
</select><br>
<input type="submit">
</form>