欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

django多對多表的創(chuàng)建,級聯(lián)刪除及手動(dòng)創(chuàng)建第三張表

 更新時(shí)間:2019年07月25日 11:01:46   作者:谷子的  
這篇文章主要介紹了django多對多表的創(chuàng)建,級聯(lián)刪除及手動(dòng)創(chuàng)建第三張表,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

創(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ù)庫,因?yàn)樾略隽硕鄬Χ嚓P(guān)系,book表會(huì)新增字段,所以直接重新生成數(shù)據(jù)庫就會(huì)報(bào)錯(cuò),

在book表里,關(guān)聯(lián)Author表,Author就要放在book表上面,

關(guān)聯(lián)的表Author加上引號是字符串,是一個(gè)查詢過程,等加載完,找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 作為一個(gè)外鍵 與Book 表建立一對多關(guān)系,默認(rèn)綁定到Book 的主鍵id上
  publish = models.ForeignKey(Publish,)

然后生成數(shù)據(jù)庫,注意:如果book表中有數(shù)據(jù),直接生成數(shù)據(jù),就會(huì)報(bào)錯(cuò),因?yàn)閎ook表會(huì)新增一個(gè)author_id 字段,而原來的book表中的數(shù)據(jù)沒有改字段,所以會(huì)報(bào)錯(cuò),刪除book表中的數(shù)據(jù)

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

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

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

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

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

#給第三張表添加關(guān)系,
  #看下authors對象

  book_obj = Book.objects.get(id=1)#獲取一個(gè)書籍的對象,有可能是多個(gè)作者寫的,是一個(gè)集合對象,

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

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

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

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

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

步驟1 ,先得到一個(gè)Book對象

book_obj = Book.objects.get(id=1)#獲取一個(gè)書籍的對象,有可能是多個(gè)作者寫的,是一個(gè)集合對象,

步驟2 :獲取1個(gè)或2個(gè)以上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個(gè)作者對象

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

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

===

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

#先獲取一個(gè)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)刪除,刪除一個(gè)對象,相關(guān)聯(lián)的一對多,多對多關(guān)系都會(huì)刪除,delte()

book_obj.delete()

----

manytomany 是django自己會(huì)生成第三張表,

自己手動(dòng)也可以創(chuàng)建第三張表

#  manytomany,會(huì)自動(dòng)生成第三張表,現(xiàn)在自己可以手動(dòng)創(chuàng)建第3張表,

class book2author(models.Model):

  book = models.ForeignKey("Book")
  author = models.ForeignKey("Author")

數(shù)據(jù)庫中就多出book2author這張表

在views視圖函數(shù)添加一條記錄

  #----給自己手動(dòng)創(chuàng)建的第三張?zhí)砑佑涗洠瑢?shí)列化對象,用save保存
  b2a = book2author(book_id=2,author_id=1)#括號里面可以寫集合,作者的集合對象,進(jìn)行關(guān)聯(lián),
  b2a.save()
  return HttpResponse('ok')

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Python標(biāo)準(zhǔn)庫之time庫的使用教程詳解

    Python標(biāo)準(zhǔn)庫之time庫的使用教程詳解

    這篇文章主要介紹了Python的time庫的使用教程,文中有非常詳細(xì)的代碼示例,對正在學(xué)習(xí)python基礎(chǔ)的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2022-04-04
  • Django打印出在數(shù)據(jù)庫中執(zhí)行的語句問題

    Django打印出在數(shù)據(jù)庫中執(zhí)行的語句問題

    這篇文章主要介紹了Django打印出在數(shù)據(jù)庫中執(zhí)行的語句,文中給大家提到了Django 查看執(zhí)行的sql語句方法,代碼簡單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-07-07
  • Python OpenCV一個(gè)窗口中顯示多幅圖像

    Python OpenCV一個(gè)窗口中顯示多幅圖像

    大家好,本篇文章主要講的是Python OpenCV一個(gè)窗口中顯示多幅圖像,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2022-01-01
  • Ubuntu20下的Django安裝的方法步驟

    Ubuntu20下的Django安裝的方法步驟

    這篇文章主要介紹了Ubuntu20下的Django安裝的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • Python實(shí)戰(zhàn)之看圖猜字游戲的實(shí)現(xiàn)

    Python實(shí)戰(zhàn)之看圖猜字游戲的實(shí)現(xiàn)

    看圖猜成語,是考驗(yàn)一個(gè)人的反應(yīng)能力,也考驗(yàn)一個(gè)人的右腦思維。據(jù)說越聰明的人,這道題的完成率越高。本文就來用Python實(shí)現(xiàn)這一經(jīng)典小游戲,需要的可以參考一下
    2023-02-02
  • tensorflow入門之訓(xùn)練簡單的神經(jīng)網(wǎng)絡(luò)方法

    tensorflow入門之訓(xùn)練簡單的神經(jīng)網(wǎng)絡(luò)方法

    本篇文章主要介紹了tensorflow入門之訓(xùn)練簡單的神經(jīng)網(wǎng)絡(luò)方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-02-02
  • python中的測試框架

    python中的測試框架

    這篇文章主要介紹了python中測試框架的相關(guān)資料,幫助大家更好的理解和使用python進(jìn)行測試,感興趣的朋友可以了解下
    2020-11-11
  • 基于Keras的格式化輸出Loss實(shí)現(xiàn)方式

    基于Keras的格式化輸出Loss實(shí)現(xiàn)方式

    這篇文章主要介紹了基于Keras的格式化輸出Loss實(shí)現(xiàn)方式,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-06-06
  • Python如何生成隨機(jī)高斯模糊圖片詳解

    Python如何生成隨機(jī)高斯模糊圖片詳解

    這篇文章主要給大家介紹了關(guān)于高斯模糊的原理以及python實(shí)現(xiàn)的相關(guān)資料,Python使用opencv庫生成模糊圖像還是很方便的,需要的朋友可以參考下
    2021-05-05
  • python多核處理器算力浪費(fèi)問題解決

    python多核處理器算力浪費(fèi)問題解決

    這篇文章主要為大家介紹了python多核處理器算力浪費(fèi)現(xiàn)象的處理,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06

最新評論