溫馨提示×

溫馨提示×

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

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

Django的models中on_delete參數是什么意思

發(fā)布時間:2021-08-25 09:39:05 來源:億速云 閱讀:129 作者:小新 欄目:開發(fā)技術

這篇文章給大家分享的是有關Django的models中on_delete參數是什么意思的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

在Django2.0以上的版本中,創(chuàng)建外鍵和一對一關系必須定義on_delete參數,我們可以在其源碼中看到相關信息

class ForeignKey(ForeignObject):
  """
  Provide a many-to-one relation by adding a column to the local model
  to hold the remote value.

  By default ForeignKey will target the pk of the remote model but this
  behavior can be changed by using the ``to_field`` argument.
  """

  # Field flags
  many_to_many = False
  many_to_one = True
  one_to_many = False
  one_to_one = False

  rel_class = ManyToOneRel

  empty_strings_allowed = False
  default_error_messages = {
    'invalid': _('%(model)s instance with %(field)s %(value)r does not exist.')
  }
  description = _("Foreign Key (type determined by related field)")

  def __init__(self, to, on_delete, related_name=None, related_query_name=None,
         limit_choices_to=None, parent_link=False, to_field=None,
         db_constraint=True, **kwargs):
  • to:關聯(lián)的表

  • on_delete:當該表中的某條數據刪除后,關聯(lián)外鍵的操作

  • related_name:反查參數,設置后可以在被關聯(lián)表中通過該字段反查外鍵所在表,默認:set_表名

  • to_field:默認主鍵,因為mysql只支持主鍵作為外鍵,就算你沒顯式的創(chuàng)建主鍵,Django會給你自動創(chuàng)建,如果你是DB-first,且沒創(chuàng)建主鍵:數據庫默認使用隱藏字段:DB_ROW_ID作為主鍵

on_delete參數設置

CASCADE:級聯(lián)刪除,當關聯(lián)表中的數據刪除時,該外鍵也刪除

PROTECT: 保護模式,如果采用該選項,刪除的時候,會拋出ProtectedError錯誤。

SET_NULL: 置空模式,刪除的時候,外鍵字段被設置為空,前提就是blank=True, null=True,定義該字段的時候,允許為空。

SET_DEFAULT: 設置默認值,刪除的時候,外鍵字段設置為默認值,所以定義外鍵的時候注意加上一個默認值。

SET(): 自定義一個值,該值當然只能是對應的實體

感謝各位的閱讀!關于“Django的models中on_delete參數是什么意思”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節(jié)

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

AI