内射老阿姨1区2区3区4区_久久精品人人做人人爽电影蜜月_久久国产精品亚洲77777_99精品又大又爽又粗少妇毛片

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

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

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

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

class Author(models.Model):

  name = models.CharField(max_length=32)

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

  # books = models.ManyToManyField(Book)

  #再重新生成數(shù)據(jù)庫(kù),因?yàn)樾略隽硕鄬?duì)多關(guān)系,book表會(huì)新增字段,所以直接重新生成數(shù)據(jù)庫(kù)就會(huì)報(bào)錯(cuò),

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

關(guān)聯(lián)的表Author加上引號(hào)是字符串,是一個(gè)查詢(xún)過(guò)程,等加載完,找Author,

就可以在全局找到,

不加引號(hào),就要把Author表放在book表上面

在book表中,創(chuàng)建與author表多對(duì)多的關(guān)系

class Book(models.Model):

  title = models.CharField(max_length=32)
  price = models.DecimalField(max_digits=5 , decimal_places=2)

  #書(shū)籍與出版社是一對(duì)多,書(shū)是多,出版社是一,外鍵(子表)建在多的表中,
  #publish 作為一個(gè)外鍵 與Book 表建立一對(duì)多關(guān)系,默認(rèn)綁定到Book 的主鍵id上
  publish = models.ForeignKey(Publish,)

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

步驟2 :獲取1個(gè)或2個(gè)以上author對(duì)象

 author1 = Author.objects.get(id=1)
 author2 = Author.objects.get(id=2)

步驟3: 把a(bǔ)uthor1,和author2 添加到 book_obj 對(duì)象中,使用add方法,書(shū)對(duì)象關(guān)聯(lián)的作者表,添加2個(gè)作者對(duì)象

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

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

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

===

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

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

#方法2 ,把所有的author加到book對(duì)象中
  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()#解除了書(shū)與作者的所有關(guān)系,

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

  book_obj.authors.remove(author)

----

級(jí)聯(lián)刪除,刪除一個(gè)對(duì)象,相關(guān)聯(lián)的一對(duì)多,多對(duì)多關(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ù)庫(kù)中就多出book2author這張表

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

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

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

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

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

廣告

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

外貿(mào)網(wǎng)站制作
建宁县| 岑巩县| 陆良县| 攀枝花市| 延长县| 巴中市| 体育| 永春县| 修文县| 丹棱县| 思南县| 措勤县| 汶川县| 广宁县| 肥乡县| 德江县| 汾阳市| 禹城市| 临猗县| 德兴市| 西藏| 晋中市| 喀什市| 梅河口市| 手机| 定南县| 灵川县| 周口市| 辉南县| 新田县| 云林县| 永顺县| 香格里拉县| 广昌县| 当雄县| 仙居县| 肇东市| 大竹县| 普兰店市| 满洲里市| 陕西省|