日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

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

發(fā)布時間:2024/6/30 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 django 多对多表的创建,级联删除,手动创建第三张表 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

創(chuàng)建一張作者表,author,創(chuàng)建外鍵與book表,多對多關(guān)系 ,外鍵字段放在那張表都可以,

class Author(models.Model):name = models.CharField(max_length=32)#在Author表中創(chuàng)建第三張表,與book表創(chuàng)建多對多關(guān)系一樣的效果# books = models.ManyToManyField(Book)#再重新生成數(shù)據(jù)庫,因為新增了多對多關(guān)系,book表會新增字段,所以直接重新生成數(shù)據(jù)庫就會報錯,
book表里,關(guān)聯(lián)Author表,Author就要放在book表上面,
關(guān)聯(lián)的表Author加上引號是字符串,是一個查詢過程,等加載完,找Author,
就可以在全局找到,

不加引號,就要把Author表放在book表上面

在book表中,創(chuàng)建與author表多對多的關(guān)系
class Book(models.Model):title = models.CharField(max_length=32)price = models.DecimalField(max_digits=5 , decimal_places=2)#書籍與出版社是一對多,書是多,出版社是一,外鍵(子表)建在多的表中,#publish 作為一個外鍵 與Book 表建立一對多關(guān)系,默認(rèn)綁定到Book 的主鍵id上publish = models.ForeignKey(Publish,)

然后生成數(shù)據(jù)庫,注意:如果book表中有數(shù)據(jù),直接生成數(shù)據(jù),就會報錯,因為book表會新增一個author_id 字段,而原來的book表中的數(shù)據(jù)沒有改字段,所以會報錯,刪除book表中的數(shù)據(jù)

執(zhí)行命令? python manage.py? makemigrations?? ,python manage.py migrate,?

在數(shù)據(jù)庫會發(fā)現(xiàn)新增一張表,book_author,是第三張表? ,一個主鍵,2個外鍵,是django自動創(chuàng)建的,現(xiàn)在就可以添加書籍

?

在創(chuàng)建的表里,手動插入數(shù)據(jù),,然后綁定book與author的多對多關(guān)系,

?

?在views視圖函數(shù)中,,先獲取Book表的一個book對象,查看該book關(guān)聯(lián)的作者,就是book_obj.authors.all(),

id =1的這本書,如果沒有關(guān)聯(lián)的作者,返回None,如果有作者,就返回一個對象集合,QuerySet數(shù)據(jù)類型,里面包含了關(guān)聯(lián)的作者對象

#給第三張表添加關(guān)系,#看下authors對象 book_obj = Book.objects.get(id=1)#獲取一個書籍的對象,有可能是多個作者寫的,是一個集合對象,#獲取id=1 這本書的作者集合對象,類似列表結(jié)構(gòu)print(book_obj.authors) #gu_orm.Author.None ,是id=1的這本書,沒有作者,所以得到一個None,-----------------------------#如果給Book和author綁定了關(guān)系,添加值,就會得到一個Queryset集合,print(book_obj.authors.all())#< QuerySet[ < Author: egon >, < Author: alex >, < Author: yuan >] >---------------------------------------

---------------

方法1:多對多關(guān)系的創(chuàng)建,獲取一個個對象,添加

現(xiàn)在用代碼實現(xiàn)多對多關(guān)系的創(chuàng)建

先刪除原第三張表的數(shù)據(jù),

步驟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: 把a(bǔ)uthor1,和author2 添加到 book_obj 對象中,使用add方法,書對象關(guān)聯(lián)的作者表,添加2個作者對象

#book表與author表綁定關(guān)系,把2個作者對象添加到,關(guān)聯(lián)到Book對象book_obj.authors.add(author1,author2)

然后再執(zhí)行url,刷新數(shù)據(jù)庫

===

方法2:多對多關(guān)系的創(chuàng)建,獲取所有的對象集合,添加 ,記得用 * 號,把列表拆開,一個個的獲取對象

 先獲取一個book對象,
book_obj = Book.objects.get(id=1)

#
方法2 ,把所有的author加到book對象中author_list = Author.objects.all()book_obj.authors.add(*author_list)

=====
解除關(guān)聯(lián)關(guān)系clear()清除所有的關(guān)系 ,remove()刪除指定的關(guān)系
#解除關(guān)聯(lián)關(guān)系book_obj.authors.clear()#解除了書與作者的所有關(guān)系,#指定刪除Book與作者的關(guān)系,先獲取要解除關(guān)聯(lián)的對象,然后用remove的方法,author = Author.objects.get(name = 'alex')book_obj.authors.remove(author)

----

級聯(lián)刪除,刪除一個對象,相關(guān)聯(lián)的一對多,多對多關(guān)系都會刪除,delte()


book_obj.delete()

----
manytomany 是django自己會生成第三張表,
自己手動也可以創(chuàng)建第三張表 # manytomany,會自動生成第三張表,現(xiàn)在自己可以手動創(chuàng)建第3張表,class book2author(models.Model):book = models.ForeignKey("Book")author = models.ForeignKey("Author") 數(shù)據(jù)庫中就多出book2author這張表

在views視圖函數(shù)添加一條記錄
#----給自己手動創(chuàng)建的第三張?zhí)砑佑涗?#xff0c;實列化對象,用save保存b2a = book2author(book_id=2,author_id=1)#括號里面可以寫集合,作者的集合對象,進(jìn)行關(guān)聯(lián), b2a.save()return HttpResponse('ok')

?

? #方法2 ,把所有的author加到book對象中
author_list = Author.objects.all()
book_obj.authors.add(*author_list)

轉(zhuǎn)載于:https://www.cnblogs.com/gyh04541/p/7912867.html

總結(jié)

以上是生活随笔為你收集整理的django 多对多表的创建,级联删除,手动创建第三张表的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。