创建一张作者表,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')
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
问题内容: 我在我的数据库3个表:,和 学生可以有多个课程,课程可以有多个学生。和之间存在多对多关系。 我为我的项目和课程添加了3个案例。 (a)当我添加用户时,它会保存得很好, (b)当我为学生添加课程时,它会在-预期行为中创建新的行。 (三)当我试图删除学生,则在删除适当的记录和,但它也删除其中不需要的记录。即使课程中没有任何用户,我也希望课程在那里。 下面是我的表和注释类的代码。 这是Hib
问题内容: 我正在使用Microsoft SQL Server Management Studio,并且在创建联结表时是否应该为联结表创建ID列,如果需要,还应将其设为主键和标识列吗?还是为我要加入的多对多关系表保留2列? 例如,如果这将是多对多表: 我应该制作联结表吗: [并将我的主键用作身份列]? 或者: [并且只保留它没有主键或身份表]? 问题答案: 我将使用第二个联结表: 主键将是两列的组
问题内容: 我正在尝试在SQL Server的同一张表之间创建多对多关系。 我有一张桌子,上面有列和。 关系遵循以下规则: 一个孩子可以有很多父母 父母可以有很多孩子 ObjectA可以是ObjectB的子代,而ObjectB可以是ObjectA的子代 但是对象不能是其本身的直接子代 所以我创建第二个表格的列和,当然我希望这些关系通过级联删除。 但是当我在SQL Server中尝试此操作时,出现错
本文向大家介绍django 多对多表的创建和插入代码实现,包括了django 多对多表的创建和插入代码实现的使用技巧和注意事项,需要的朋友参考一下 这篇文章主要介绍了django-多对多表的创建和插入代码实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 表的创建 数据的添加 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐
问题内容: 我在我的数据库3个表:,和 学生可以有多个课程,课程可以有多个学生。和之间存在多对多关系。 我为我的项目和课程添加了3个案例。 (a)当我添加用户时,它会保存得很好, (b)当我为学生添加课程时,它将在-预期行为中再次创建新行。 (三)当我试图删除学生,则在删除适当的记录和,但它也删除其中不需要的记录。即使课程中没有任何用户,我也希望课程在那里。 下面是我的表和注释类的代码。 这是Hi