django多对多表的创建,级联删除及手动创建第三张表

 更新时间:2019年07月25日 11:01:46   作者:谷子的  
这篇文章主要介绍了django多对多表的创建,级联删除及手动创建第三张表,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

创建一张作者表,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')

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 人工智能—Python实现线性回归

    人工智能—Python实现线性回归

    这篇文章主要介绍了人工智能—Python实现线性回归,人工智能分为类型、数据集、效果评估、等,线性回归根据随机初始化的 w x b 和 y 来计算 loss等步骤实现,下面来看看文章的具体实现吧
    2022-01-01
  • 简单介绍Python中的floor()方法

    简单介绍Python中的floor()方法

    这篇文章主要介绍了Python中的floor()方法,是Python入门的基础知识,需要的朋友可以参考下
    2015-05-05
  • 基于Python实现的车牌识别系统

    基于Python实现的车牌识别系统

    本文将以基于Python的车牌识别系统实现为方向,介绍车牌识别技术的基本原理、常用算法和方法,并详细讲解如何利用Python语言实现一个完整的车牌识别系统,需要的朋友可以参考下
    2023-10-10
  • python使用matplotlib绘制柱状图教程

    python使用matplotlib绘制柱状图教程

    这篇文章主要介绍了python使用matplotlib绘制柱状图的方法教程,其中实现的柱状图效果包括基本的柱状图、堆叠柱状图、并列柱状图、条形图以及柱状图的各种样式设置,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-02-02
  • Matplotlab显示OpenCV读取到的图像

    Matplotlab显示OpenCV读取到的图像

    本文介绍了如何使用OpenCV和Matplotlib处理图像,本文通过实例讲解的非常详细,对Matplotlab OpenCV图像相关处理方法感兴趣的朋友一起看看吧
    2025-02-02
  • Python爬虫新手入门之初学lxml库

    Python爬虫新手入门之初学lxml库

    这篇文章主要给大家介绍了关于Python爬虫新手入门之初学lxml库的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • python 实现tar文件压缩解压的实例详解

    python 实现tar文件压缩解压的实例详解

    这篇文章主要介绍了python 实现tar文件压缩解压的实例详解的相关资料,这里提供实现方法,帮助大家学习理解这部分内容,需要的朋友可以参考下
    2017-08-08
  • Python cookbook(数据结构与算法)字典相关计算问题示例

    Python cookbook(数据结构与算法)字典相关计算问题示例

    这篇文章主要介绍了Python字典相关计算问题,结合实例形式总结分析了Python字典相关的最小值、最大值、排序等操作相关实现技巧,需要的朋友可以参考下
    2018-02-02
  • Python使用ntplib库同步校准当地时间的方法

    Python使用ntplib库同步校准当地时间的方法

    NTP网络时间协议其实大家平时或多或少都能接触到,包括Windows在内的操作系统中的很多Internet时间同步功能都是在NTP的基础上来做,这里我们来看一下Python使用ntplib库同步校准当地时间的方法
    2016-07-07
  • python利用xpath爬取网上数据并存储到django模型中

    python利用xpath爬取网上数据并存储到django模型中

    这篇文章主要介绍了python利用xpath爬取网上数据并存储到django模型中,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-02-02

最新评论