django多对多表的创建,级联删除及手动创建第三张表
作者:谷子的 发布时间:2022-08-13 02:10:48
创建一张作者表,author,创建外键与book表,多对多关系 ,外键字段放在那张表都可以,
class Author(models.Model):
name = models.CharField(max_length=32)
#在Author表中创建第三张表,与book表创建多对多关系一样的效果
# books = models.ManyToManyField(Book)
#再重新生成数据库,因为新增了多对多关系,book表会新增字段,所以直接重新生成数据库就会报错,
在book表里,关联Author表,Author就要放在book表上面,
关联的表Author加上引号是字符串,是一个查询过程,等加载完,找Author,
就可以在全局找到,
不加引号,就要把Author表放在book表上面
在book表中,创建与author表多对多的关系
class Book(models.Model):
title = models.CharField(max_length=32)
price = models.DecimalField(max_digits=5 , decimal_places=2)
#书籍与出版社是一对多,书是多,出版社是一,外键(子表)建在多的表中,
#publish 作为一个外键 与Book 表建立一对多关系,默认绑定到Book 的主键id上
publish = models.ForeignKey(Publish,)
然后生成数据库,注意:如果book表中有数据,直接生成数据,就会报错,因为book表会新增一个author_id 字段,而原来的book表中的数据没有改字段,所以会报错,删除book表中的数据
执行命令 python manage.py makemigrations ,python manage.py migrate,
在数据库会发现新增一张表,book_author,是第三张表 ,一个主键,2个外键,是django自动创建的,现在就可以添加书籍
在创建的表里,手动插入数据,,然后绑定book与author的多对多关系,
在views视图函数中,,先获取Book表的一个book对象,查看该book关联的作者,就是book_obj.authors.all(),
id =1的这本书,如果没有关联的作者,返回None,如果有作者,就返回一个对象集合,QuerySet数据类型,里面包含了关联的作者对象
#给第三张表添加关系,
#看下authors对象
book_obj = Book.objects.get(id=1)#获取一个书籍的对象,有可能是多个作者写的,是一个集合对象,
#获取id=1 这本书的作者集合对象,类似列表结构
print(book_obj.authors) #gu_orm.Author.None ,是id=1的这本书,没有作者,所以得到一个None,-----------------------------
#如果给Book和author绑定了关系,添加值,就会得到一个Queryset集合,
print(book_obj.authors.all())
#< QuerySet[ < Author: egon >, < Author: alex >, < Author: yuan >] >---------------------------------------
---------------
方法1:多对多关系的创建,获取一个个对象,添加
现在用代码实现多对多关系的创建
先删除原第三张表的数据,
步骤1 ,先得到一个Book对象
book_obj = Book.objects.get(id=1)#获取一个书籍的对象,有可能是多个作者写的,是一个集合对象,
步骤2 :获取1个或2个以上author对象
author1 = Author.objects.get(id=1)
author2 = Author.objects.get(id=2)
步骤3: 把author1,和author2 添加到 book_obj 对象中,使用add方法,书对象关联的作者表,添加2个作者对象
#book表与author表绑定关系,把2个作者对象添加到,关联到Book对象
book_obj.authors.add(author1,author2)
然后再执行url,刷新数据库
===
方法2:多对多关系的创建,获取所有的对象集合,添加 ,记得用 * 号,把列表拆开,一个个的获取对象
#先获取一个book对象,
book_obj = Book.objects.get(id=1)
#方法2 ,把所有的author加到book对象中
author_list = Author.objects.all()
book_obj.authors.add(*author_list)
=====
解除关联关系clear()清除所有的关系 ,remove()删除指定的关系
#解除关联关系
book_obj.authors.clear()#解除了书与作者的所有关系,
#指定删除Book与作者的关系,先获取要解除关联的对象,然后用remove的方法,
author = Author.objects.get(name = 'alex')
book_obj.authors.remove(author)
----
级联删除,删除一个对象,相关联的一对多,多对多关系都会删除,delte()
book_obj.delete()
----
manytomany 是django自己会生成第三张表,
自己手动也可以创建第三张表
# manytomany,会自动生成第三张表,现在自己可以手动创建第3张表,
class book2author(models.Model):
book = models.ForeignKey("Book")
author = models.ForeignKey("Author")
数据库中就多出book2author这张表
在views视图函数添加一条记录
#----给自己手动创建的第三张添加记录,实列化对象,用save保存
b2a = book2author(book_id=2,author_id=1)#括号里面可以写集合,作者的集合对象,进行关联,
b2a.save()
return HttpResponse('ok')
来源:https://www.cnblogs.com/gyh04541/p/7912867.html
猜你喜欢
- 本文系统的对HTTP Headers进行了简明易懂的阐述,我仅稍作笔记。什么是HTTP HeadersHTTP是“Hypertext Tra
- 说到Javascript的类继承,就必然离不开原型链,但只通过原型链实现的继承有着不少缺陷。无参数类继承的问题先看一段示例代码,实现B继承于
- python3中,list有个reverse函数,用来反转列表元素,但是如果想要反转部分元素呢?a = [1,2,3,4,5]a[0:3].
- 见下表:序号列类型需要的存储量1TINYINT1 字节2SMALLINT2 个字节3MEDIUMINT3 个字节4INT4 个字节5INTE
- 如下所示:from pymongo import MongoClient#建立和数据库系统的连接,指定host及port参数client =
- 如下所示:#!/usr/bin/env python#_*_ coding:utf-8 _*_name = ['hello'
- 最近在代码评审的过程,发现挺多错误使用eval导致代码注入的问题,比较典型的就是把eval当解析dict使用,有的就是简单的使用eval,有
- 前言本文的操作环境:ubuntu,Python2.7,采用的是Pycharm进行代码编辑,个人很喜欢它的代码自动补齐功能。示例图如上图,我们
- 这两天为用bottle+mongodb写的一个项目加上登录功能,无奈怎么都获取不到保存的cookie,文档给出让我们这样操作cookie的代
- 四年前写的一个内容管理系统,应用在公司内部网上,昨天DBA说其中的SQL语句未使用参数化的调用,导致服务器负担加重,资源占用大。并列出了几个
- 简介观察者模式是行为型模式的一种,定义了对象间一对多的关系。当对象的状态发生变化时候,依赖于它的对象会得到通知。适用场景类似触发钩子事件,可
- 一、读取整个文件内容在读取文件之前,我们先创建一个文本文件resource.txt作为源文件。resource.txtmy name is
- 要下午传上的.结果事一多,忘记了.好不容易回来 . 这个和 dh20156 的那个,是差不多的。 找不到合适的图片,也
- 概述gRPC 是谷歌开源的一个rpc(远程程序调用)框架,可以轻松实现跨语言,跨平台编程,其采用gRPC协议(基于HTTP2)。rpc:re
- 本文实例为大家分享了python实现大量图片重命名的具体代码,供大家参考,具体内容如下说明在进行深度学习的过程中,需要对图片进行批量的命名处
- 本文实例讲述了Python使用dict.fromkeys()快速生成一个字典。分享给大家供大家参考,具体如下:>>> re
- 忙碌了一年,今天终于放假了。原本打算好好休息一下,没成想只过了半天就觉得有点无聊。看家人和朋友们都在忙年,那我就用OpenGL导演一场烟花盛
- pytorch里面的maxpool,有一个属性叫ceil_mode,这个属性在api里面的解释是ceil_mode: when True,
- 本文介绍了使用XMlhttp技术来生成html页面,值得借鉴。相关函数:<% ’定义xmlhttp funct
- python中的多线程其实并不是真正的多线程,如果想要充分地使用多核CPU的资源,在python中大部分情况需要使用多进程。Python提供