亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Django中ORM外鍵與表的關系是什么

發布時間:2021-01-18 16:00:27 來源:億速云 閱讀:192 作者:Leah 欄目:開發技術

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

外鍵

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

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

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 來定義模型之間的關系。即在 article 的實例中可以通過 author 屬性來操作對應的 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 訪問到對應的 user 對象呢。因此在底層, Django 為 Article 表添加了一個 屬性名_id 的字段(比如author的字段名稱是author_id),這個字段是一個外鍵,記錄著對應的作者的主鍵。以后通過 article.author 訪問的時候,實際上是先通過 author_id 找到對應的數據,然后再提取 User 表中的這條數據,形成一個模型。

如果想要引用另外一個 app 的模型,那么應該在傳遞 to 參數的時候,使用 app.model_name 進行指定。以上例為例,如果 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 參數可以為 'self' ,或者是這個模型的名字。在論壇開發中,一般評論都可以進行二級評論,即可以針對另外一個評論進行評論,那么在定義模型的時候就需要使用外鍵來引用自身。示例代碼如下:

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)

外鍵刪除操作:

如果一個模型使用了外鍵。那么在對方那個模型被刪掉后,該進行什么樣的操作。可以通過 on_delete 來指定。可以指定的類型如下:

  1. CASCADE :級聯操作。如果外鍵對應的那條數據被刪除了,那么這條數據也會被刪除。

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

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

  4. SET_DEFAULT :設置默認值。如果外鍵的那條數據被刪除了,那么本條數據上就將這個字段設置為默認值。如果設置這個選項,前提是要指定這個字段一個默認值。

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

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

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

登封市| 大丰市| 营口市| 贡山| 永清县| 海安县| 正镶白旗| 图们市| 法库县| 桐梓县| 灵璧县| 巴中市| 开原市| 临澧县| 平阳县| 通河县| 鄂托克旗| 平罗县| 邹城市| 巴楚县| 宁城县| 滁州市| 固原市| 尚志市| 合肥市| 荔浦县| 尖扎县| 大埔区| 芒康县| 宜城市| 勐海县| 新邵县| 百色市| 专栏| 明光市| 金山区| 科技| 丹阳市| 华坪县| 扬州市| 合江县|