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')
 
        

 

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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM