Django中ORM外鍵與表的關(guān)系是什么-創(chuàng)新互聯(lián)

Django中ORM外鍵與表的關(guān)系是什么?很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。

成都創(chuàng)新互聯(lián)長(zhǎng)期為千余家客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺(tái),與合作伙伴共同營(yíng)造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為右江企業(yè)提供專業(yè)的做網(wǎng)站、網(wǎng)站設(shè)計(jì),右江網(wǎng)站改版等技術(shù)服務(wù)。擁有10余年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。

外鍵

在 MySQL 中,表有兩種引擎,一種是 InnoDB ,另外一種是 myisam 。如果使用的是 InnoDB 引擎,是支持外鍵約束的。外鍵的存在使得 ORM 框架在處理表關(guān)系的時(shí)候異常的強(qiáng)大。因此這里我們首先來介紹下外鍵在 Django 中的使用。

類定義為 class ForeignKey(to,on_delete,**options) 。第一個(gè)參數(shù)是引用的是哪個(gè)模型,第二個(gè)參數(shù)是在使用外鍵引用的模型數(shù)據(jù)被刪除了,這個(gè)字段該如何處理,比如有 CASCADE 、 SET_NULL 等。這里以一個(gè)實(shí)際案例來說明。比如有一個(gè) User 和一個(gè) Article 兩個(gè)模型。一個(gè) User 可以發(fā)表多篇文章,一個(gè) Article 只能有一個(gè) Author ,并且通過外鍵進(jìn)行引用。那么相關(guān)的示例代碼如下:

class User(models.Model):
  username = models.CharField(max_length=20)
  password = models.CharField(max_length=100)

class Article(models.Model):
  title = models.CharField(max_length=100)
  content = models.TextField()

  author = models.ForeignKey("User",on_delete=models.CASCADE)

以上使用 ForeignKey 來定義模型之間的關(guān)系。即在 article 的實(shí)例中可以通過 author 屬性來操作對(duì)應(yīng)的 User 模型。這樣使用起來非常的方便。示例代碼如下:

article = Article(title='abc',content='123')
author = User(username='張三',password='111111')
article.author = author
article.save()

# 修改article.author上的值
article.author.username = '李四'
article.save()

為什么使用了 ForeignKey 后,就能通過 author 訪問到對(duì)應(yīng)的 user 對(duì)象呢。因此在底層, Django 為 Article 表添加了一個(gè) 屬性名_id 的字段(比如author的字段名稱是author_id),這個(gè)字段是一個(gè)外鍵,記錄著對(duì)應(yīng)的作者的主鍵。以后通過 article.author 訪問的時(shí)候,實(shí)際上是先通過 author_id 找到對(duì)應(yīng)的數(shù)據(jù),然后再提取 User 表中的這條數(shù)據(jù),形成一個(gè)模型。

如果想要引用另外一個(gè) app 的模型,那么應(yīng)該在傳遞 to 參數(shù)的時(shí)候,使用 app.model_name 進(jìn)行指定。以上例為例,如果 User 和 Article 不是在同一個(gè) app 中,那么在引用的時(shí)候的示例代碼如下:

# User模型在user這個(gè)app中
class User(models.Model):
  username = models.CharField(max_length=20)
  password = models.CharField(max_length=100)

# Article模型在article這個(gè)app中
class Article(models.Model):
  title = models.CharField(max_length=100)
  content = models.TextField()

  author = models.ForeignKey("user.User",on_delete=models.CASCADE)

如果模型的外鍵引用的是本身自己這個(gè)模型,那么 to 參數(shù)可以為 'self' ,或者是這個(gè)模型的名字。在論壇開發(fā)中,一般評(píng)論都可以進(jìn)行二級(jí)評(píng)論,即可以針對(duì)另外一個(gè)評(píng)論進(jìn)行評(píng)論,那么在定義模型的時(shí)候就需要使用外鍵來引用自身。示例代碼如下:

class Comment(models.Model):
  content = models.TextField()
  origin_comment = models.ForeignKey('self',on_delete=models.CASCADE,null=True)
  # 或者
  # origin_comment = models.ForeignKey('Comment',on_delete=models.CASCADE,null=True)

外鍵刪除操作:

如果一個(gè)模型使用了外鍵。那么在對(duì)方那個(gè)模型被刪掉后,該進(jìn)行什么樣的操作??梢酝ㄟ^ on_delete 來指定??梢灾付ǖ念愋腿缦拢?/p>

  1. CASCADE :級(jí)聯(lián)操作。如果外鍵對(duì)應(yīng)的那條數(shù)據(jù)被刪除了,那么這條數(shù)據(jù)也會(huì)被刪除。

  2. PROTECT :受保護(hù)。即只要這條數(shù)據(jù)引用了外鍵的那條數(shù)據(jù),那么就不能刪除外鍵的那條數(shù)據(jù)。

  3. SET_NULL :設(shè)置為空。如果外鍵的那條數(shù)據(jù)被刪除了,那么在本條數(shù)據(jù)上就將這個(gè)字段設(shè)置為空。如果設(shè)置這個(gè)選項(xiàng),前提是要指定這個(gè)字段可以為空。

  4. SET_DEFAULT :設(shè)置默認(rèn)值。如果外鍵的那條數(shù)據(jù)被刪除了,那么本條數(shù)據(jù)上就將這個(gè)字段設(shè)置為默認(rèn)值。如果設(shè)置這個(gè)選項(xiàng),前提是要指定這個(gè)字段一個(gè)默認(rèn)值。

  5. SET() :如果外鍵的那條數(shù)據(jù)被刪除了。那么將會(huì)獲取 SET 函數(shù)中的值來作為這個(gè)外鍵的值。 SET 函數(shù)可以接收一個(gè)可以調(diào)用的對(duì)象(比如函數(shù)或者方法),如果是可以調(diào)用的對(duì)象,那么會(huì)將這個(gè)對(duì)象調(diào)用后的結(jié)果作為值返回回去。

  6. DO_NOTHING :不采取任何行為。一切全看數(shù)據(jù)庫級(jí)別的約束。

看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道,感謝您對(duì)創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司的支持。

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、網(wǎng)站設(shè)計(jì)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

當(dāng)前題目:Django中ORM外鍵與表的關(guān)系是什么-創(chuàng)新互聯(lián)
鏈接地址:http://bm7419.com/article0/ceojoo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供商城網(wǎng)站、網(wǎng)站內(nèi)鏈、面包屑導(dǎo)航網(wǎng)站導(dǎo)航、建站公司關(guān)鍵詞優(yōu)化

廣告

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

成都網(wǎng)頁設(shè)計(jì)公司