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

Django中ORM外鍵和表的關(guān)系詳解

 更新時間:2019年05月20日 08:27:29   作者:KadyCui  
這篇文章主要介紹了Django中ORM外鍵和表的關(guān)系詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

外鍵

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

類定義為 class ForeignKey(to,on_delete,**options) 。第一個參數(shù)是引用的是哪個模型,第二個參數(shù)是在使用外鍵引用的模型數(shù)據(jù)被刪除了,這個字段該如何處理,比如有 CASCADE 、 SET_NULL 等。這里以一個實際案例來說明。比如有一個 User 和一個 Article 兩個模型。一個 User 可以發(fā)表多篇文章,一個 Article 只能有一個 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 的實例中可以通過 author 屬性來操作對應(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 訪問到對應(yīng)的 user 對象呢。因此在底層, Django 為 Article 表添加了一個 屬性名_id 的字段(比如author的字段名稱是author_id),這個字段是一個外鍵,記錄著對應(yīng)的作者的主鍵。以后通過 article.author 訪問的時候,實際上是先通過 author_id 找到對應(yīng)的數(shù)據(jù),然后再提取 User 表中的這條數(shù)據(jù),形成一個模型。

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

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

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

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

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

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)

外鍵刪除操作:

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

  1. CASCADE :級聯(lián)操作。如果外鍵對應(yīng)的那條數(shù)據(jù)被刪除了,那么這條數(shù)據(jù)也會被刪除。
  2. PROTECT :受保護(hù)。即只要這條數(shù)據(jù)引用了外鍵的那條數(shù)據(jù),那么就不能刪除外鍵的那條數(shù)據(jù)。
  3. SET_NULL :設(shè)置為空。如果外鍵的那條數(shù)據(jù)被刪除了,那么在本條數(shù)據(jù)上就將這個字段設(shè)置為空。如果設(shè)置這個選項,前提是要指定這個字段可以為空。
  4. SET_DEFAULT :設(shè)置默認(rèn)值。如果外鍵的那條數(shù)據(jù)被刪除了,那么本條數(shù)據(jù)上就將這個字段設(shè)置為默認(rèn)值。如果設(shè)置這個選項,前提是要指定這個字段一個默認(rèn)值。
  5. SET() :如果外鍵的那條數(shù)據(jù)被刪除了。那么將會獲取 SET 函數(shù)中的值來作為這個外鍵的值。 SET 函數(shù)可以接收一個可以調(diào)用的對象(比如函數(shù)或者方法),如果是可以調(diào)用的對象,那么會將這個對象調(diào)用后的結(jié)果作為值返回回去。
  6. DO_NOTHING :不采取任何行為。一切全看數(shù)據(jù)庫級別的約束。

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

相關(guān)文章

  • YOLOv5車牌識別實戰(zhàn)教程(八)Web應(yīng)用與API開發(fā)

    YOLOv5車牌識別實戰(zhàn)教程(八)Web應(yīng)用與API開發(fā)

    這篇文章主要介紹了YOLOv5車牌識別實戰(zhàn)教程(八)Web應(yīng)用與API開發(fā),在這個教程中,我們將一步步教你如何使用YOLOv5進(jìn)行車牌識別,幫助你快速掌握YOLOv5車牌識別技能,需要的朋友可以參考下
    2023-04-04
  • Python巧用SnowNLP實現(xiàn)生成srt字幕文件

    Python巧用SnowNLP實現(xiàn)生成srt字幕文件

    SnowNLP是一個可以方便的處理中文文本內(nèi)容的python類庫,本文主要為大家詳細(xì)介紹了Python如何巧用SnowNLP實現(xiàn)將一段話一鍵生成srt字幕文件,感興趣的可以了解下
    2024-01-01
  • Python標(biāo)準(zhǔn)庫datetime之datetime模塊用法分析詳解

    Python標(biāo)準(zhǔn)庫datetime之datetime模塊用法分析詳解

    這篇文章主要介紹了Python標(biāo)準(zhǔn)庫datetime之datetime模塊用法分析詳解,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-07-07
  • python實現(xiàn)梯度下降算法的實例詳解

    python實現(xiàn)梯度下降算法的實例詳解

    在本篇文章里小編給大家整理的是一篇關(guān)于python實現(xiàn)梯度下降算法的實例詳解內(nèi)容,需要的朋友們可以參考下。
    2020-08-08
  • python包pdfkit(wkhtmltopdf)?將HTML轉(zhuǎn)換為PDF的操作方法

    python包pdfkit(wkhtmltopdf)?將HTML轉(zhuǎn)換為PDF的操作方法

    pdfkit,把HTML+CSS格式的文件轉(zhuǎn)換成PDF格式文檔的一種工具。它就是html轉(zhuǎn)成pdf工具包wkhtmltopdf的Python封裝。所以,必須手動安裝wkhtmltopdf,這篇文章主要介紹了python包pdfkit(wkhtmltopdf)將HTML轉(zhuǎn)換為PDF,需要的朋友可以參考下
    2022-04-04
  • pandas讀取excel時獲取讀取進(jìn)度的實現(xiàn)

    pandas讀取excel時獲取讀取進(jìn)度的實現(xiàn)

    這篇文章主要介紹了pandas讀取excel時獲取讀取進(jìn)度的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • python 含子圖的gif生成時內(nèi)存溢出的方法

    python 含子圖的gif生成時內(nèi)存溢出的方法

    今天小編就為大家分享一篇python 含子圖的gif生成時內(nèi)存溢出的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07
  • pyQt4實現(xiàn)俄羅斯方塊游戲

    pyQt4實現(xiàn)俄羅斯方塊游戲

    這篇文章主要為大家詳細(xì)介紹了pyQt4實現(xiàn)俄羅斯方塊游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-06-06
  • Python 實現(xiàn)大整數(shù)乘法算法的示例代碼

    Python 實現(xiàn)大整數(shù)乘法算法的示例代碼

    這篇文章主要介紹了Python 實現(xiàn)大整數(shù)乘法算法的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • python實現(xiàn)圖像全景拼接

    python實現(xiàn)圖像全景拼接

    這篇文章主要為大家詳細(xì)介紹了python實現(xiàn)圖像全景拼接,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-03-03

最新評論