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自动创建的,现在就可以添加书籍

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

在创建的表里,手动插入数据,,然后绑定book与author的多对多关系,

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

在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,刷新数据库

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

===

方法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

标签:django,多对多,表,创建,级联删除
0
投稿

猜你喜欢

  • MySQL 字符串截取相关函数小结

    2024-01-14 21:37:14
  • Golang Compare And Swap算法详细介绍

    2024-02-19 16:08:02
  • python PyAutoGUI 模拟鼠标键盘操作和截屏功能

    2022-11-12 08:16:41
  • 必须会的SQL语句(四) 数据删除和更新

    2024-01-29 02:11:51
  • 解决sql server保存对象字符串转换成uniqueidentifier失败的问题

    2024-01-20 01:22:59
  • pytorch的Backward过程用时太长问题及解决

    2022-12-11 00:16:06
  • 网页打开速度的心理学

    2009-03-26 13:18:00
  • Python面向对象之接口、抽象类与多态详解

    2021-10-24 10:26:48
  • MySQL错误TIMESTAMP column with CURRENT_TIMESTAMP的解决方法

    2024-01-25 20:47:47
  • python读取txt数据的操作步骤

    2022-12-27 10:36:31
  • Python解析命令行读取参数之argparse模块

    2021-12-17 22:15:32
  • Python编程pytorch深度卷积神经网络AlexNet详解

    2022-02-18 10:28:40
  • Python反爬虫技术之防止IP地址被封杀的讲解

    2022-05-09 10:44:12
  • python绘制双柱形图代码实例

    2022-02-28 19:42:27
  • javascript定时变换图片实例代码

    2024-04-17 10:24:14
  • asp 解析一个xml文件的公用函数集合

    2008-02-29 13:40:00
  • 浅谈Mysql tinyint(1)与tinyint(4)的区别

    2024-01-14 10:10:39
  • python3模拟实现xshell远程执行linux命令的方法

    2022-05-26 11:45:14
  • Python类的基本写法与注释风格介绍

    2023-01-15 07:53:52
  • python多进程执行方法apply_async使用说明

    2023-01-31 11:56:10
  • asp之家 网络编程 m.aspxhome.com