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')

如图:


cm_host.png
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')

创建的表:


创建的表名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 %}
    <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>
网页展示效果.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

<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>
image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容