亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Django中ORM基本應(yīng)用與原理解析

 更新時(shí)間:2022年10月13日 10:41:19   作者:世界盡頭與你  
Django的ORM模塊是框架特色功能之一,它把數(shù)據(jù)表與Python類對(duì)應(yīng)、表字段與類屬性對(duì)應(yīng)、類實(shí)例與數(shù)據(jù)記錄對(duì)應(yīng),并將對(duì)類實(shí)例的操作映射到數(shù)據(jù)庫(kù)中,這篇文章主要介紹了Django?ORM基本應(yīng)用與原理剖析,需要的朋友可以參考下

1.ORM構(gòu)建數(shù)據(jù)表

由于每一個(gè)數(shù)據(jù)表對(duì)應(yīng)一個(gè)Model定義,每一個(gè)Model都是一個(gè)Python類,所以,Model之間是可以繼承的。Django規(guī)定,所有的Model都必須繼承自django.db.models.Model

Model中的所有字段都是django.db.models.Field的子類,Django會(huì)根據(jù)Field的類型確定數(shù)據(jù)庫(kù)表的字段類型

首先定義定義抽象Model基類:

class BaseModel(models.Model):
    class Meta:
        # 抽象類,表現(xiàn)為BaseModel不會(huì)創(chuàng)建數(shù)據(jù)表
        abstract = True
        # 按照創(chuàng)建時(shí)間逆序排序
        ordering = ['-created_time']

    # 定義了兩個(gè)類屬性:created_time和last_modified,且都是DateTimeField類型
    # auto_now_add用于將首次創(chuàng)建對(duì)象時(shí)間設(shè)置為當(dāng)前時(shí)間
    # auto_now用于將每次保存對(duì)象時(shí)間設(shè)置為當(dāng)前時(shí)間
    created_time = models.DateTimeField(auto_now_add=True, help_text=u'創(chuàng)建時(shí)間')
    last_modified = models.DateTimeField(auto_now=True, help_text=u'修改時(shí)間')

    # 優(yōu)化打印(print)Model實(shí)例的樣式
    def __str__(self):
        raise NotImplementedError

由于BaseModel直接繼承自django.db.models.Model,所以,我們創(chuàng)建的實(shí)體數(shù)據(jù)表可以繼承自Base Model,從而實(shí)現(xiàn)間接繼承

例如:話題表

class Topic(BaseModel):
    title = models.CharField(max_length=255, unique=True, help_text=u'話題標(biāo)題')
    content = models.TextField(help_text=u'話題內(nèi)容')
    is_online = models.BooleanField(default=True, help_text=u'話題是否在線')
    user = models.ForeignKey(to=User, to_field='id', on_delete=models.CASCADE, help_text=u'關(guān)聯(lián)用戶表')

    def __str__(self):
        return '%d:%s' % (self.id, self.title[0:20])

Topic中除了基本類型的字段定義之外,還包含了一個(gè)外鍵(ForeignKey)引用的user字段

評(píng)論表:

class Comment(BaseModel):
    content = models.CharField(max_length=255, help_text=u'話題評(píng)論')
    topic = models.ForeignKey(to=Topic, to_field='id', on_delete=models.CASCADE, help_text=u'關(guān)聯(lián)話題表')
    up = models.IntegerField(default=0, help_text=u'支持')
    down = models.IntegerField(default=0, help_text=u'反對(duì)')

    def __str__(self):
        return '%d:%s' % (self.id, self.content[0:20])

2.數(shù)據(jù)遷移

首先,在settings.py文件中添加此Model視圖的app:(post.apps.PostConfig

INSTALLED_APPS = [
    'post.apps.PostConfig',
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
]

生成遷移文件:

python manage.py makemigrations post

執(zhí)行migrate命令將Models映射為數(shù)據(jù)庫(kù)的表:

python manage.py migrate

生成的表結(jié)構(gòu):

3.Model相關(guān)的概念與使用方法

Model的組成部分

每個(gè)Model都是一個(gè)Python類,且通常會(huì)包含四個(gè)部分:繼承自django.db.models.Model、Model元數(shù)據(jù)聲明(Meta內(nèi)部類)、若干個(gè)Field類型的字段以及__str__方法

Meta元數(shù)據(jù)類屬性說明

Meta類用于定義Model的元數(shù)據(jù),即不屬于Model的字段,但是可以用來標(biāo)識(shí)它的一些屬性

abstract:

一個(gè)布爾類型的變量,如果設(shè)置為True,則標(biāo)識(shí)當(dāng)前的Model是抽象基類,這個(gè)元選項(xiàng)不具有傳遞性,只對(duì)當(dāng)前聲明的類有效。例如,對(duì)于之前定義的BaseModel,用abstract聲明為抽象基類,但是子類Topic和Comment不受影響

db_table:

這個(gè)字段用于指定數(shù)據(jù)表的名稱

默認(rèn)會(huì)使用Django的表名生成規(guī)則,例如Topic會(huì)映射到post_topic表。如果想讓Topic映射到topic表,定義db_table='topic'即可

ordering:

用于指定獲取對(duì)象列表時(shí)的排序規(guī)則

按照created_time逆序排序,可以定義:

ordering = ['-created_time']

先按照created_time逆序排序,再按照last_modified正序排序:

ordering = ['-created_time', 'last_modified']

indexes:

它是一個(gè)列表類型的元選項(xiàng),用來定義Model的索引

  • fields:一個(gè)列表對(duì)象,用于指定索引的字段,是必填項(xiàng),且至少包含一個(gè)字段。
  • name:用于標(biāo)識(shí)索引的名稱,是可選的,如果不提供,Django會(huì)根據(jù)不同的數(shù)據(jù)庫(kù)生成合適的索引名。
  • db_tablespace:表空間,也是可選的,常見于PostgreSQL、Oracle數(shù)據(jù)庫(kù),用于優(yōu)化數(shù)據(jù)庫(kù)性能

unique_together:

標(biāo)識(shí)聯(lián)合唯一約束,在數(shù)據(jù)庫(kù)層面表現(xiàn)為聯(lián)合唯一索引

Field的通用字段選項(xiàng)

blank:

對(duì)于任何一個(gè)屬性,默認(rèn)是不允許輸入空值的,如果允許這種情況發(fā)生,需要設(shè)置blank=True

unique:

如果一個(gè)字段設(shè)置了unique=True,則表示唯一性索引

null:

規(guī)定這個(gè)字段的數(shù)據(jù)是否可以是空值

db_index:

如果該字段經(jīng)常作為查詢的條件,那么就需要考慮設(shè)置db_index選項(xiàng),以加快數(shù)據(jù)的檢索速度

default:

用于給字段設(shè)置默認(rèn)值

choices:

設(shè)置了choices的字段在管理后臺(tái)的顯示上會(huì)由文本框變成選擇框,選擇框中的可選值就是choices中的元組

help_text:

這個(gè)選項(xiàng)用于在表單中顯示字段的提示信息。例如在管理后臺(tái)的編輯頁(yè)面,對(duì)應(yīng)在字段輸入框的下方會(huì)顯示該選項(xiàng)設(shè)定的值

基礎(chǔ)字段類型

  • IntegerField:整型字段
  • Django還提供了SmallIntegerField(小整數(shù))、BigIntegerField(64位整數(shù))和PositiveIntegerField(只允許存儲(chǔ)大于等于0的整數(shù))等字段類型用來滿足存儲(chǔ)整數(shù)的不同業(yè)務(wù)場(chǎng)景
  • AutoField:一個(gè)根據(jù)ID自增的IntegerField
  • 如果覺得AutoField的取值范圍不夠用,可以考慮使用BigAutoField
  • CharField:字符字段
  • TextField:也是用于存儲(chǔ)字符類型的字段,但是它用于存儲(chǔ)大文本
  • BooleanField:布爾類型
  • DateField和DateTimeField:標(biāo)識(shí)時(shí)間的
  • 它們都有兩個(gè)特殊的參數(shù)選項(xiàng)可以設(shè)置
  • ①auto_now:這個(gè)選項(xiàng)應(yīng)用在對(duì)象保存的時(shí)候,會(huì)自動(dòng)設(shè)置為當(dāng)前時(shí)間
  • ②auto_now_add:當(dāng)首次創(chuàng)建對(duì)象的時(shí)候,會(huì)自動(dòng)將字段設(shè)置為當(dāng)前時(shí)間
  • EmailField:專門用來存儲(chǔ)電子郵件地址的
  • 除了之前介紹的幾種常見的類型之外,還有GenericIPAddressField用于存儲(chǔ)IP地址、URLField用于存儲(chǔ)URL、FloatField用于存儲(chǔ)浮點(diǎn)數(shù)的字段類型等

關(guān)系字段類型

多對(duì)一

實(shí)例:

user = models.ForeignKey(to=User, to_field='id', on_delete=models.CASCADE, help_text=u'關(guān)聯(lián)用戶表')

to:指定所關(guān)聯(lián)的Model

on_delete:當(dāng)刪除關(guān)聯(lián)表的數(shù)據(jù)時(shí),Django將根據(jù)這個(gè)參數(shù)設(shè)定的值確定應(yīng)該執(zhí)行什么樣的SQL約束

  • CASCADE:級(jí)聯(lián)刪除,它是大部分ForeignKey的定義應(yīng)該選擇的約束。它的表現(xiàn)是刪除了“一”,則“多”會(huì)被自動(dòng)刪除
  • PROTECT:刪除被引用對(duì)象時(shí),將會(huì)拋出ProtectedError異常
  • SET_NULL:設(shè)置刪除對(duì)象所關(guān)聯(lián)的外鍵字段為null。以Topic和Comment的關(guān)系舉例:刪除了Topic,與之相關(guān)聯(lián)的Comment的topic字段會(huì)被設(shè)置為null
  • SET_DEFAULT:將外鍵字段設(shè)置為默認(rèn)值
  • SET(value):刪除被引用對(duì)象時(shí),設(shè)置外鍵字段為value
  • DO_NOTHING:不做任何處理

一對(duì)一

實(shí)例:

user = models.OneToOneField(to=User, on_delete=models.CASCADE, parent_link=False,
                             help_text=u'關(guān)聯(lián)用戶表')

多對(duì)多關(guān)系類型

實(shí)例:

books = models.ManyToManyField(to=Book)

到此這篇關(guān)于Django ORM基本應(yīng)用與原理剖析的文章就介紹到這了,更多相關(guān)Django ORM原理內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • pycharm如何設(shè)置官方中文(如何漢化)

    pycharm如何設(shè)置官方中文(如何漢化)

    這篇文章主要介紹了pycharm如何設(shè)置官方中文(如何漢化),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • python 獲取字符串MD5值方法

    python 獲取字符串MD5值方法

    今天小編就為大家分享一篇python 獲取字符串MD5值方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-05-05
  • 用Python和WordCloud繪制詞云的實(shí)現(xiàn)方法(內(nèi)附讓字體清晰的秘笈)

    用Python和WordCloud繪制詞云的實(shí)現(xiàn)方法(內(nèi)附讓字體清晰的秘笈)

    這篇文章主要介紹了用Python和WordCloud繪制詞云的實(shí)現(xiàn)方法(內(nèi)附讓字體清晰的秘笈),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-01-01
  • Python實(shí)現(xiàn)簡(jiǎn)單的代理服務(wù)器

    Python實(shí)現(xiàn)簡(jiǎn)單的代理服務(wù)器

    這篇文章主要介紹了Python實(shí)現(xiàn)簡(jiǎn)單的代理服務(wù)器,可實(shí)現(xiàn)代理服務(wù)器基本的包轉(zhuǎn)發(fā)功能,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-07-07
  • python矩陣的轉(zhuǎn)置和逆轉(zhuǎn)實(shí)例

    python矩陣的轉(zhuǎn)置和逆轉(zhuǎn)實(shí)例

    今天小編就為大家分享一篇python矩陣的轉(zhuǎn)置和逆轉(zhuǎn)實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-12-12
  • 基于Python進(jìn)行年齡和性別檢測(cè)

    基于Python進(jìn)行年齡和性別檢測(cè)

    這篇文章主要介紹了通過Python 編程語言帶您完成使用機(jī)器學(xué)習(xí)進(jìn)行年齡和性別檢測(cè)的任務(wù)。文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下
    2021-12-12
  • Python實(shí)現(xiàn)樹莓派攝像頭持續(xù)錄像并傳送到主機(jī)的步驟

    Python實(shí)現(xiàn)樹莓派攝像頭持續(xù)錄像并傳送到主機(jī)的步驟

    這篇文章主要介紹了Python實(shí)現(xiàn)樹莓派攝像頭持續(xù)錄像并傳送到主機(jī)的步驟,幫助大家更好的理解和學(xué)習(xí)python,感興趣的朋友可以了解下
    2020-11-11
  • Python中集合的內(nèi)置函數(shù)詳解

    Python中集合的內(nèi)置函數(shù)詳解

    這篇文章主要介紹了Python中集合的內(nèi)置函數(shù)詳解,集合在python里面是另外一種對(duì)象,它的特征是在大括號(hào)里面,并且各個(gè)元素是唯一的,今天我們來看一下其內(nèi)置了哪些函數(shù),需要的朋友可以參考下
    2023-08-08
  • 用python寫個(gè)博客遷移工具

    用python寫個(gè)博客遷移工具

    這篇文章主要介紹了如何用python寫個(gè)博客遷移工具,幫助大家更好的理解和學(xué)習(xí)使用python,感興趣的朋友可以了解下
    2021-03-03
  • Python六大開源框架對(duì)比

    Python六大開源框架對(duì)比

    在這篇文章里,我們將為Python Web開發(fā)者回顧基于Python的6大Web應(yīng)用框架。無論你是出于愛好還是需求,這六大框架都可能會(huì)成為你工作上不錯(cuò)的得力助手。
    2015-10-10

最新評(píng)論