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

簡單了解Django ORM常用字段類型及參數配置

 更新時間:2020年01月07日 14:53:34   作者:子欽加油  
這篇文章主要介紹了簡單了解Django ORM常用字段類型及參數配置,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

這篇文章主要介紹了簡單了解Django ORM常用字段類型及參數配置,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

一、數值型

  • AutoField對應int(11)。自增主鍵,Django Model默認提供,可以被重寫。
  • BooleanField對應tinyint(1)。布爾類型字段,一般用于記錄狀態(tài)標記。
  • DecimalField對應decimal。開發(fā)對數據精準要求較高大的業(yè)務時考慮使用。比如:cash=models.DecimalField(max_length, decimal_places=2, default=0, verbose_name=“消費金額”),就是定義長度為8位、精度位2位的數字,例如數字:666666.66。
  • IntergerField對應**int(11) **。同AutoField一樣,唯一的差別就是不自增。
  • PositiveIntegerField。同IntegerField,只包含正整數。
  • SmallIntegerField對應smallint。小整數時一般會用到。

二、字符型

django對應到Mysql中有兩種類型:longtext和varchar。

​ 除了TextField是longtest類型外,其他屬于varchar類型。

  • CharField對應varchar?;A的varchar類型。
  • URLField.繼承自CharField,但是實現了對URL特特殊處理。用來存儲URL數據,非URL數據可以在業(yè)務層就拒絕掉,不會存入數據庫中。
  • UUIDField對應char(32)。除了在PostgreSQL中使用的是uuid類型外,在其他數據庫中均是固定長度char(32),用來存放生成的唯一id。
  • EmailField。同URLfield一樣繼承自CharField,多了對email的特殊處理。
  • FileField。同URLField一樣,它繼承自CharField,對了對文件的特殊處理。
  • TextField對應longtext。一般用于存放大量文本內容,比如新聞正文、博客正文。
  • ImageField。繼承自FileField,用來處理圖片相關的數據,在展示上會有所不同。

三、日期類型

django中有3中日期類型,分別對應Mysql的date、datetime和time

  • DateField對應date
  • DateTimeField對應datetime
  • TimeField對應time

四、關系類型

  • ForeignKey,外鍵
  • OneToOneField,一對一
  • ManyToManyField,多對多

五、參數

上面django所提供的字段都是類。

比如models.CharField的定義就是:class CharField:。

每個字段里面都提供了參數可以選擇:

  • null。可以同blank進行對比。null用于設定在數據庫層面是否允許為空
  • blank。針對業(yè)務層面,該值是否允許為空。
  • choices。配置字段的choices后,在admin頁面上就可以看到對應的可選項展示。
  • db_column。默認情況下,定義的field就是對應數據庫中的字段名稱,通過這個參數可以指定Model中的某個字段對應數據庫中的哪個字段。
  • db_index。數據庫索引配置。
  • default。默認值配置。
  • editable。是否可編輯,默認是True。如果不想這個字段顯示在頁面上,可以配置為False。
  • error_messages。用來自定義字段值校驗失敗時的異常提示,它是字典格式。key的值可選項為null、blank、invalid、invalid_choice、unique和unique_for_date。
  • help_text。字段提示語,配置這一項后,在頁面對應字段的下方會展示此配置。
  • primary_key。主鍵,一個Model只允許設置一個字段為primary_key。
  • unique。唯一約束,當需要配置唯一值時,設置unique=True,設置此項后,不需要設置db_index。
  • unique_for_date。針對date(日期)的聯合約束。比如說一天只能寫一篇博文,即:unique_for_date=“博文”
  • unique_for_month。針對月份的聯合約束 。
  • unique_for_month。針對年份的聯合約束。
  • verbose_name。字段對應的展示文案。
  • validators。自定義校驗邏輯,同form類似。

關于Django字段類型中 blank和null的區(qū)別

blank

設置為True時,字段可以為空。設置為False時,字段是必須填寫的。字符型字段CharField和TextField是用空字符串來存儲空值的。

如果為True,字段允許為空,默認不允許。

null

設置為True時,django用Null來存儲空值。日期型、時間型和數字型字段不接受空字符串。所以設置IntegerField,DateTimeField型字段可以為空時,需要將blank,null均設為True。

如果為True,空值將會被存儲為NULL,默認為False。

如果想設置BooleanField為空時可以選用NullBooleanField型字段。

一句話概括

  • null 是針對數據庫而言,如果 null=True, 表示數據庫的該字段可以為空。
  • blank 是針對表單的,如果 blank=True,表示你的表單填寫該字段的時候可以不填,比如 admin 界面下增加 model 一條記錄的時候。直觀的看到就是該字段不是粗體
  • 通俗點說,該字段null=true后,你進行插入,修改操作時可以為空,然后Django把空值轉換成null存在數據庫中,而blank只是在表單驗證的時候會檢測你是否可以為空

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 解決Python網頁爬蟲之中文亂碼問題

    解決Python網頁爬蟲之中文亂碼問題

    今天小編就為大家分享一篇解決Python網頁爬蟲之中文亂碼問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-05-05
  • Python數據庫安裝及MySQL?Connector應用教程

    Python數據庫安裝及MySQL?Connector應用教程

    這篇文章主要為大家介紹了Python數據庫安裝及MySQL Connector應用教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11
  • Opencv對象追蹤的示例代碼

    Opencv對象追蹤的示例代碼

    這篇文章主要介紹了Opencv對象追蹤的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-03-03
  • Python數據分析之?Matplotlib?3D圖詳情

    Python數據分析之?Matplotlib?3D圖詳情

    本文主要介紹了Python數據分析之Matplotlib 3D圖詳情,Matplotlib提供了mpl_toolkits.mplot3d工具包來進行3D圖表的繪制,下文總結了更多相關資料,需要的小伙伴可以參考一下
    2022-05-05
  • Python多線程原理與用法詳解

    Python多線程原理與用法詳解

    這篇文章主要介紹了Python多線程原理與用法,簡單描述了多線程的概念、原理并結合實例形式分析了Python多線程創(chuàng)建、啟動、各種鎖機制、隊列及相關函數使用技巧,需要的朋友可以參考下
    2018-08-08
  • python opencv 檢測移動物體并截圖保存實例

    python opencv 檢測移動物體并截圖保存實例

    這篇文章主要介紹了python opencv 檢測移動物體并截圖保存實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-03-03
  • python偏函數partial用法

    python偏函數partial用法

    這篇文章要給大家分享得是python偏函數partial用法,主要介紹什么是偏函數partial、偏函數的作用、偏函數的語法及案例詳情,需要的朋友可以參考一下文章得具體詳解,希望對你有所幫助
    2021-10-10
  • Python Socket使用實例

    Python Socket使用實例

    這篇文章主要介紹了Python Socket使用實例,具有一定借鑒價值,需要的朋友可以參考下。
    2017-12-12
  • 淺談Python中的常用內置對象

    淺談Python中的常用內置對象

    今天帶大家復習Python基礎知識,文中對Python常用的內置對象作了非常詳細的介紹及代碼示例,對正在學習python的小伙伴們很有幫助,需要的朋友可以參考下
    2021-05-05
  • Python 3.8中實現functools.cached_property功能

    Python 3.8中實現functools.cached_property功能

    這篇文章主要介紹了Python 3.8中實現functools.cached_property功能,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-05-05

最新評論