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


Posted in Python onJuly 25, 2019

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

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

Python 相关文章推荐
在Python中封装GObject模块进行图形化程序编程的教程
Apr 14 Python
Python连接MySQL并使用fetchall()方法过滤特殊字符
Mar 13 Python
python+tkinter编写电脑桌面放大镜程序实例代码
Jan 16 Python
Python实现简易版的Web服务器(推荐)
Jan 29 Python
pygame游戏之旅 按钮上添加文字的方法
Nov 21 Python
配置 Pycharm 默认 Test runner 的图文教程
Nov 30 Python
Django+Xadmin构建项目的方法步骤
Mar 06 Python
Python爬取破解无线网络wifi密码过程解析
Sep 17 Python
python下载库的步骤方法
Oct 12 Python
python paramiko远程服务器终端操作过程解析
Dec 14 Python
对tensorflow中tf.nn.conv1d和layers.conv1d的区别详解
Feb 11 Python
Python爬虫工具requests-html使用解析
Apr 29 Python
django 中QuerySet特性功能详解
Jul 25 #Python
对Python _取log的几种方式小结
Jul 25 #Python
django 中的聚合函数,分组函数,F 查询,Q查询
Jul 25 #Python
python使用paramiko模块通过ssh2协议对交换机进行配置的方法
Jul 25 #Python
python2 中 unicode 和 str 之间的转换及与python3 str 的区别
Jul 25 #Python
Python 3.8 新功能全解
Jul 25 #Python
python3.7 的新特性详解
Jul 25 #Python
You might like
PHP中利用substr_replace将指定两位置之间的字符替换为*号
2011/01/27 PHP
使用php清除bom示例
2014/03/03 PHP
ThinkPHP的I方法使用详解
2014/06/18 PHP
php文件下载处理方法分析
2015/04/22 PHP
PHP实现负载均衡的加权轮询方法分析
2018/08/22 PHP
thinkphp框架类库扩展操作示例
2019/11/26 PHP
qTip2 精致的基于jQuery提示信息插件
2012/02/17 Javascript
jquery实现div拖拽宽度示例代码
2013/07/31 Javascript
AngularJS入门教程之服务(Service)
2016/07/27 Javascript
vue.js学习之递归组件
2016/12/13 Javascript
JS实现图片放大缩小的方法
2017/02/15 Javascript
微信小程序实战之顶部导航栏(选项卡)(1)
2020/06/19 Javascript
深入理解jquery的$.extend()、$.fn和$.fn.extend()
2017/07/08 jQuery
Bootstrap模态对话框用法简单示例
2018/08/31 Javascript
从0到1构建vueSSR项目之路由的构建
2019/03/07 Javascript
vue仿ios列表左划删除
2019/09/26 Javascript
微信小程序实现注册登录功能(表单校验、错误提示)
2019/12/10 Javascript
[54:06]OG vs TNC 2018国际邀请赛小组赛BO2 第二场 8.19
2018/08/21 DOTA
Python 探针的实现原理
2016/04/23 Python
pycharm+django创建一个搜索网页实例代码
2018/01/24 Python
python 字符串只保留汉字的方法
2018/11/16 Python
Python中logging实例讲解
2019/01/17 Python
Python实现合并两个有序链表的方法示例
2019/01/31 Python
python实现切割url得到域名、协议、主机名等各个字段的例子
2019/07/25 Python
python3 使用traceback定位异常实例
2020/03/09 Python
CSS实现圆形放大镜狙击镜效果 只有圆圈里的放大
2012/12/10 HTML / CSS
伦敦香水公司:The London Perfume Company
2019/11/13 全球购物
保险专业大专生求职信
2013/10/26 职场文书
杠杆的科学教学反思
2014/01/10 职场文书
校园餐饮创业计划书
2014/01/10 职场文书
写好自荐信需做到的5要点
2014/03/07 职场文书
出纳试用期自我鉴定范文
2014/09/16 职场文书
2014年世界艾滋病日宣传活动总结
2014/11/18 职场文书
小学生作文评语集锦
2014/12/25 职场文书
python中24小时制转换为12小时制的方法
2021/06/18 Python
mybatis3中@SelectProvider传递参数方式
2021/08/04 Java/Android