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

Python Django ORM與模型詳解

 更新時間:2021年11月11日 08:45:38   作者:久醉繞心弦,  
這篇文章主要介紹了django的ORM與模型的實現原理,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧v

一、 環(huán)境準備:

1.docker環(huán)境

docker環(huán)境如下:

在這里插入圖片描述

2.安裝mariadb數據庫

運行如下命令

docker run -d --name [容器名稱] -v test:/var/lib/mysql -p 3306:3306 --env MARIADB_USER=[用戶名] --env MARIADB_PASSWORD=[用戶密碼] --env MARIADB_ROOT_PASSWORD=[root用戶密碼] --env MARIADB_DATABASE=[庫名] mariadb:latest

參數詳解:

  • name:啟動容器設置容器名稱
  • v:設置容器目錄/var/lib/mysql映射到本地目錄test
  • p:設置容器的3306端口映射到主機3306端口
  • env:設置環(huán)境變量數據庫相關信息
  • d:后臺運行容器mariadb并返回容器id
  • mariadb:latest:啟動最新的鏡像版本

等待命令運行結束后可以查看啟動的容器:

在這里插入圖片描述

navicat連接測試:

在這里插入圖片描述

創(chuàng)建好的數據庫:

在這里插入圖片描述

二、ORM

1.ORM簡介

orm(object relational mapping )對象關系映射,用面向對象的方式,描述數據庫,操作數據庫,達到不編寫sql語句就可以對數據庫進行增刪改查的一種技術,但是orm底層還是通過原生sql去實現的。

在這里插入圖片描述

上圖所示,而模型的對象就相當于表中數據。

2.django配置數據庫

在配置數據庫前需要安裝mysql驅動,此環(huán)境用的是mariadb數據庫,安裝驅動:

pip install mysqlclient

安裝完成后可以通過如下兩種方式添加配置信息:

第一種方式:

直接在settings.py中配置:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': '庫名',
        'USER': '用戶名',
        'PASSWORD': '用戶密碼',
        'HOST': '域名',
        'PORT': '端口號'
    }
}

第二種方式:

添加配置文件:

根目錄下新建配置文件目錄,并創(chuàng)建配置文件填寫數據庫信息:

# my.cnf
[client]
database = 庫名
user = 用戶名
password = 用戶密碼
host = 域名
port = 端口

settings.py 中

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'OPTIONS': {
            'read_default_file': str(BASE_DIR / [配置文件路徑])
        }
    }
}

三、模型設計

django中的模型準確且唯一的描述了數據,每個模型都是一個python類,繼承django.db.models.Model類。模型類中的每個熟悉為數據庫中的字段,diango提供了一個自動生成訪問數據庫的API。

1.創(chuàng)建模型

每個應用的模型都會被編寫到models.py文件下,如圖,創(chuàng)建項目時會自動引入models模塊。

在這里插入圖片描述

創(chuàng)建一個學生表為例:

from django.db import models


# Create your models here.

class Stutent(models.Model):
    """
    學生表
    """
    name = models.CharField('學生姓名', max_length=200, unique=True, help_text='學生姓名')
    sex = models.CharField('性別', max_length=48, help_text='性別')
    hobby = models.CharField('愛好', max_length=200, null=True, blank=True, help_text='興趣愛好')
    create_time = models.DateTimeField('創(chuàng)建時間', auto_now_add=True, help_text='創(chuàng)建時間')

    class Meta:
        """
        元數據,
        """
        db_table = 'student'  # 指定當前模型創(chuàng)建的表明,不寫默認當前的模型名Student
        verbose_name = '學生信息表'  # 注釋
        verbose_name_plural = verbose_name  # 指定為復數
        ordering = ['-create_time'] # 使用創(chuàng)建時間倒序排序,不加-為正序

CharField   字符類型代表數據庫中的VARCHAR
DateTimeField  日期字段類型
IntegerField  整數字段類型
FloatField  數值字段類型
DecimalField  高精度字段類型
max_length  數據的長度限制,當使用CharField時,此字段必傳,否則報錯
unique 為True  代表字段唯一
null 為True  代表可以為空
blank 為True  不校驗此字段
SmallIntegerField 小整數
auto_now_add  結合DateTimeField 使用,默認為當前時間

2.表關系

Django中的表關系可以通過下面方式表達

一對多關系:models.ForeignKey()        在多的一方創(chuàng)建
多對多關系:models.ManyToManyField()   隨便表創(chuàng)建
一對一關系:models.OneToOneField()     隨便表創(chuàng)建

繼續(xù)創(chuàng)建學生班級模型:

class Class(models.Model):
    name = models.CharField('班級名稱', max_length=200)
    class_num = models.IntegerField('班級', unique=True, help_text='班級number')
    student = models.ForeignKey(Stutent, on_delete=models.CASCADE)  # 設置外鍵,on_delete級聯刪除

四、模型應用

數據庫遷移前需要將應用在settings文件的INSTALLED_APPS中去注冊

在這里插入圖片描述

第一步:

生成數據遷移記錄
python manage.py makemigrations projects

運行命令后會在migrations目錄下生成遷移記錄文件,id會自動創(chuàng)建,如下:

在這里插入圖片描述

django底層是用sql實現的,查看執(zhí)行遷移生成的sql命令如下:

python manage.py sqlmigrate projects 0001

在這里插入圖片描述

第二步:

執(zhí)行遷移

python manage.py migrate 

執(zhí)行命令后數據庫生成表信息

在這里插入圖片描述

總結

本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關注腳本之家的更多內容!

相關文章

  • python如何生成網頁驗證碼

    python如何生成網頁驗證碼

    這篇文章主要為大家詳細介紹了python如何生成網頁驗證碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • Python詞云展示庫wordcloud配置詳解

    Python詞云展示庫wordcloud配置詳解

    這篇文章主要介紹了Python詞云展示庫wordcloud配置詳解,詞云就是將詞語通過圖形可視化的方式,直觀和藝術的展示出來,詞云在我們的生活中經常能夠看到,無論是中文的詞云還是英文的詞云,需要的朋友可以參考下
    2023-07-07
  • python清空命令行方式

    python清空命令行方式

    今天小編就為大家分享一篇python清空命令行方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-01-01
  • Django中的文件的上傳的幾種方式

    Django中的文件的上傳的幾種方式

    這篇文章主要介紹了Django中的文件的上傳的幾種方式,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-07-07
  • python之語句mode = 'test' if y is None else 'train'問題

    python之語句mode = 'test' if y&nb

    這篇文章主要介紹了python之語句mode = 'test' if y is None else 'train'問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • 使用Flask-Cache緩存實現給Flask提速的方法詳解

    使用Flask-Cache緩存實現給Flask提速的方法詳解

    這篇文章主要介紹了使用Flask-Cache緩存實現給Flask提速的方法,結合實例形式詳細分析了Flask-Cache的安裝、配置及緩存使用相關操作技巧,需要的朋友可以參考下
    2019-06-06
  • python for循環(huán)內輸出和外輸出方式

    python for循環(huán)內輸出和外輸出方式

    這篇文章主要介紹了python for循環(huán)內輸出和外輸出方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-03-03
  • python如何調用php文件中的函數詳解

    python如何調用php文件中的函數詳解

    這篇文章主要給大家介紹了關于python如何調用php文件中函數的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12
  • python框架flask入門之路由及簡單實現方法

    python框架flask入門之路由及簡單實現方法

    這篇文章主要介紹了python框架flask入門路由及路由簡單實現方法,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06
  • Flask之閃現flash原理及使用

    Flask之閃現flash原理及使用

    Flask中的閃現是一種在請求之間傳遞消息的機制,本文就來介紹一下Flask之閃現flash原理及使用,具有一定的參考價值,感興趣的可以了解一下
    2023-12-12

最新評論