Django模型層

Django模型

一钻哩、基礎(chǔ)

  • 每個(gè)模型都是一個(gè) Python 的類诫肠,這些類繼承自 django.db.models.Model。
  • 模型類的每個(gè)屬性都相當(dāng)于一個(gè)數(shù)據(jù)庫的字段。

模型基本結(jié)構(gòu):

class 模型名(機(jī)器讀)(models.Model):
    字段名(機(jī)器讀) = models.字段類型Field(參數(shù)設(shè)置)

    def __str__(self):
        return self.字段名

    class Meta:
        db_table = "表名(機(jī)器讀)"
        verbose_name = '可讀模型名(人可讀)'
        verbose_name_plural = '復(fù)數(shù)形式可讀模型名(人可讀)'

二厉亏、使用模型

1.應(yīng)用路由配置

工程目錄下urls.py

from django.contrib import admin
from django.urls import path, include

urlpatterns = [
    path('admin/', admin.site.urls),
    path('應(yīng)用名/', include('應(yīng)用名.urls')),
]

2.應(yīng)用配置

settings.py

INSTALLED_APPS = [
    # 自定義
    '應(yīng)用名.apps.應(yīng)用名(首字母大寫)Config',

    # Django自帶
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',

    # 第三方
    'widget_tweaks',
]

3.數(shù)據(jù)庫配置

settings.py

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': '數(shù)據(jù)庫名',
        'USER': 'root',
        'PASSWORD': '',
        'HOST': '127.0.0.1',
        'PORT': '3306',
    }
}

4.數(shù)據(jù)庫遷移

完成應(yīng)用的模型代碼編寫后,可運(yùn)行以下命令激活模型:

...\> python manage.py makemigrations
...\> python manage.py migrate

三、字段

文檔:https://docs.djangoproject.com/zh-hans/2.2/ref/models/fields/

1.字段類型

(1)自增列

字段類型 描述
AutoField 自增列
BigAutoField 大自增列,1 ~ 9223372036854775807

注意:自增列必須填入?yún)?shù) primary_key=True莱找。
如果model中沒有自增列,則自動(dòng)會(huì)創(chuàng)建一個(gè)列名為id的自增列嗜桌。

(2)數(shù)值型

字段類型 描述
BinaryField 二進(jìn)制型列
SmallIntegerField 小整數(shù)列奥溺,-32768 ~ 32767
PositiveSmallIntegerField 正小整數(shù)列,0 ~ 32767
IntegerField 整數(shù)列(有符號(hào)的)骨宠,-2147483648 ~ 2147483647
PositiveIntegerField 正整數(shù)列谚赎,0 ~ 2147483647
BigIntegerField 長整數(shù)列(有符號(hào)的) ,-9223372036854775808 ~ 9223372036854775807
BooleanField 布爾型列诱篷,不允許為空
NullBooleanField 布爾型列壶唤,允許為空
FloatField 浮點(diǎn)型列
DecimalField 十進(jìn)制小數(shù)列(max_digits:總長度,decimal_places:小數(shù)位數(shù))

(3)字符串型

字段類型 描述
CharField 可變長字符型列(varchar)棕所,必須提供max_length參數(shù)闸盔, max_length表示字符長度
TextField 長文本型列(longtext)

(4)日期型

字段類型 描述
DateField 日期型列,YYYY-MM-DD
TimeField 時(shí)間型列琳省,HH:MM[:ss[.uuuuuu]]
DateTimeField 日期時(shí)間型列迎吵,YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ]
DurationField 時(shí)間間隔型列

(5)其他類型

字段類型 描述
EmailField 郵箱列,Django Admin以及ModelForm中提供驗(yàn)證機(jī)制
IPAddressField IPV4地址列针贬,Django Admin以及ModelForm中提供驗(yàn)證IPV4 機(jī)制
GenericIPAddressField IP地址列击费,Django Admin以及ModelForm中提供Ipv4和Ipv6驗(yàn)證機(jī)制

(6)Django字段數(shù)據(jù)庫字段對(duì)照

'AutoField': 'integer AUTO_INCREMENT',
'BigAutoField': 'bigint AUTO_INCREMENT',
'BinaryField': 'longblob',
'BooleanField': 'bool',
'CharField': 'varchar(%(max_length)s)',
'CommaSeparatedIntegerField': 'varchar(%(max_length)s)',
'DateField': 'date',
'DateTimeField': 'datetime',
'DecimalField': 'numeric(%(max_digits)s, %(decimal_places)s)',
'DurationField': 'bigint',
'FileField': 'varchar(%(max_length)s)',
'FilePathField': 'varchar(%(max_length)s)',
'FloatField': 'double precision',
'IntegerField': 'integer',
'BigIntegerField': 'bigint',
'IPAddressField': 'char(15)',
'GenericIPAddressField': 'char(39)',
'NullBooleanField': 'bool',
'OneToOneField': 'integer',
'PositiveIntegerField': 'integer UNSIGNED',
'PositiveSmallIntegerField': 'smallint UNSIGNED',
'SlugField': 'varchar(%(max_length)s)',
'SmallIntegerField': 'smallint',
'TextField': 'longtext',
'TimeField': 'time',
'UUIDField': 'char(32)',

2.字段選項(xiàng)

字段參數(shù) 描述
null 數(shù)據(jù)庫中字段是否可以為空(null=True)
db_column 數(shù)據(jù)庫中字段的列名(db_column="test")
db_tablespace 指定這個(gè)模型對(duì)應(yīng)的數(shù)據(jù)庫表放在哪個(gè)數(shù)據(jù)庫表空間
default 數(shù)據(jù)庫中字段的默認(rèn)值
primary_key 數(shù)據(jù)庫中字段是否為主鍵(primary_key=True)
db_index 數(shù)據(jù)庫中字段是否可以建立索引(db_index=True)
unique 數(shù)據(jù)庫中字段是否可以建立唯一索引(unique=True)
unique_for_date 數(shù)據(jù)庫中字段【日期】部分是否可以建立唯一索引
unique_for_month 數(shù)據(jù)庫中字段【月】部分是否可以建立唯一索引
unique_for_year 數(shù)據(jù)庫中字段【年】部分是否可以建立唯一索引
auto_now 更新時(shí)自動(dòng)更新當(dāng)前時(shí)間
auto_now_add 創(chuàng)建時(shí)自動(dòng)更新當(dāng)前時(shí)間
verbose_name Admin中顯示的字段名稱
blank Admin中是否允許用戶輸入為空 表單提交時(shí)可以為空
editable Admin中是否可以編輯
help_text Admin中該字段的提示信息
choices Admin中顯示選擇框的內(nèi)容,用不變動(dòng)的數(shù)據(jù)放在內(nèi)存中從而避免跨表操作

四桦他、Meta選項(xiàng)

元數(shù)據(jù) 描述
app_label 指定該模型屬于哪一個(gè)應(yīng)用
db_table 表名(機(jī)器讀)
db_tablespace 定義數(shù)據(jù)庫表空間的名字
get_latest_by 指定lastest()方法的參照字段
managed 指定是否根據(jù)模型類生成映射的數(shù)據(jù)庫表(默認(rèn)為True)
order_with_respect_to 按照給定的字段把這個(gè)對(duì)象標(biāo)記為”可排序的“
ordering 指定排序的參照字段
permissions 設(shè)置創(chuàng)建對(duì)象時(shí)權(quán)限表中額外的權(quán)限
unique_together 設(shè)置的不重復(fù)的字段組合
index_together 設(shè)置帶有索引的字段組合
abstract 指定該模型是否作為基類用于被繼承
proxy 指定該模型子類的另一個(gè)模型是否會(huì)被視為代理模型
verbose_name 可讀模型名(人可讀)
verbose_name_plural 復(fù)數(shù)形式可讀模型名(人可讀)
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末蔫巩,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子快压,更是在濱河造成了極大的恐慌圆仔,老刑警劉巖,帶你破解...
    沈念sama閱讀 210,978評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蔫劣,死亡現(xiàn)場離奇詭異坪郭,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)脉幢,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,954評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門歪沃,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人嫌松,你說我怎么就攤上這事沪曙。” “怎么了豆瘫?”我有些...
    開封第一講書人閱讀 156,623評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵珊蟀,是天一觀的道長。 經(jīng)常有香客問我,道長育灸,這世上最難降的妖魔是什么腻窒? 我笑而不...
    開封第一講書人閱讀 56,324評(píng)論 1 282
  • 正文 為了忘掉前任,我火速辦了婚禮磅崭,結(jié)果婚禮上儿子,老公的妹妹穿的比我還像新娘。我一直安慰自己砸喻,他們只是感情好柔逼,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,390評(píng)論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著割岛,像睡著了一般愉适。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上癣漆,一...
    開封第一講書人閱讀 49,741評(píng)論 1 289
  • 那天维咸,我揣著相機(jī)與錄音,去河邊找鬼惠爽。 笑死癌蓖,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的婚肆。 我是一名探鬼主播租副,決...
    沈念sama閱讀 38,892評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼较性!你這毒婦竟也來了用僧?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,655評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤两残,失蹤者是張志新(化名)和其女友劉穎永毅,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體人弓,經(jīng)...
    沈念sama閱讀 44,104評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年着逐,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了崔赌。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,569評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡耸别,死狀恐怖健芭,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情秀姐,我是刑警寧澤慈迈,帶...
    沈念sama閱讀 34,254評(píng)論 4 328
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響痒留,放射性物質(zhì)發(fā)生泄漏谴麦。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,834評(píng)論 3 312
  • 文/蒙蒙 一伸头、第九天 我趴在偏房一處隱蔽的房頂上張望匾效。 院中可真熱鬧,春花似錦恤磷、人聲如沸面哼。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,725評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽魔策。三九已至,卻和暖如春河胎,著一層夾襖步出監(jiān)牢的瞬間代乃,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,950評(píng)論 1 264
  • 我被黑心中介騙來泰國打工仿粹, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留搁吓,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,260評(píng)論 2 360
  • 正文 我出身青樓吭历,卻偏偏與公主長得像堕仔,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子晌区,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,446評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容