成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

怎么在django中創(chuàng)建多對多表-創(chuàng)新互聯(lián)

怎么在django中創(chuàng)建多對多表?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。

網(wǎng)站制作、網(wǎng)站建設服務團隊是一支充滿著熱情的團隊,執(zhí)著、敏銳、追求更好,是創(chuàng)新互聯(lián)的標準與要求,同時竭誠為客戶提供服務是我們的理念。創(chuàng)新互聯(lián)公司把每個網(wǎng)站當做一個產品來開發(fā),精雕細琢,追求一名工匠心中的細致,我們更用心!

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

class Author(models.Model):

  name = models.CharField(max_length=32)

  #在Author表中創(chuàng)建第三張表,與book表創(chuàng)建多對多關系一樣的效果

  # books = models.ManyToManyField(Book)

  #再重新生成數(shù)據(jù)庫,因為新增了多對多關系,book表會新增字段,所以直接重新生成數(shù)據(jù)庫就會報錯,

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

關聯(lián)的表Author加上引號是字符串,是一個查詢過程,等加載完,找Author,

就可以在全局找到,

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

在book表中,創(chuàng)建與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,)

然后生成數(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)在就可以添加書籍

怎么在django中創(chuàng)建多對多表

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

怎么在django中創(chuàng)建多對多表

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

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

#給第三張表添加關系,
  #看下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:多對多關系的創(chuàng)建,獲取一個個對象,添加

現(xiàn)在用代碼實現(xià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: 把author1,和author2 添加到 book_obj 對象中,使用add方法,書對象關聯(lián)的作者表,添加2個作者對象

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

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

怎么在django中創(chuàng)建多對多表

===

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

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

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

=====

解除關聯(lián)關系clear()清除所有的關系 ,remove()刪除指定的關系

#解除關聯(lián)關系
  book_obj.authors.clear()#解除了書與作者的所有關系,

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

  book_obj.authors.remove(author)

----

級聯(lián)刪除,刪除一個對象,相關聯(liá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í)砑佑涗?,實列化對象,用save保存
  b2a = book2author(book_id=2,author_id=1)#括號里面可以寫集合,作者的集合對象,進行關聯(lián),
  b2a.save()
  return HttpResponse('ok')

看完上述內容,你們掌握怎么在django中創(chuàng)建多對多表的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!

網(wǎng)站題目:怎么在django中創(chuàng)建多對多表-創(chuàng)新互聯(lián)
分享網(wǎng)址:http://jinyejixie.com/article30/iciso.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設計、網(wǎng)站策劃外貿網(wǎng)站建設、建站公司網(wǎng)站內鏈網(wǎng)站維護

廣告

聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

外貿網(wǎng)站制作
安塞县| 永平县| 丰宁| 湖北省| 益阳市| 平罗县| 澎湖县| 临城县| 万宁市| 新昌县| 芒康县| 尉氏县| 报价| 成武县| 板桥市| 太仆寺旗| 大石桥市| 株洲县| 和政县| 东海县| 巧家县| 苏州市| 霞浦县| 崇州市| 丰宁| 武强县| 灌南县| 平陆县| 友谊县| 社旗县| 阳谷县| 天等县| 焦作市| 界首市| 土默特左旗| 五华县| 西峡县| 徐水县| 裕民县| 博兴县| 卓资县|