Python Django ORM與模型詳解
一、 環(huán)境準(zhǔn)備:
1.docker環(huán)境
docker環(huán)境如下:
2.安裝mariadb數(shù)據(jù)庫(kù)
運(yùn)行如下命令
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=[庫(kù)名] mariadb:latest
參數(shù)詳解:
name
:?jiǎn)?dòng)容器設(shè)置容器名稱
v
:設(shè)置容器目錄/var/lib/mysql映射到本地目錄test
p
:設(shè)置容器的3306端口映射到主機(jī)3306端口
env
:設(shè)置環(huán)境變量數(shù)據(jù)庫(kù)相關(guān)信息
d
:后臺(tái)運(yùn)行容器mariadb并返回容器id
mariadb:latest
:?jiǎn)?dòng)最新的鏡像版本
等待命令運(yùn)行結(jié)束后可以查看啟動(dòng)的容器:
navicat連接測(cè)試:
創(chuàng)建好的數(shù)據(jù)庫(kù):
二、ORM
1.ORM簡(jiǎn)介
orm(object relational mapping )對(duì)象關(guān)系映射,用面向?qū)ο蟮姆绞剑枋鰯?shù)據(jù)庫(kù),操作數(shù)據(jù)庫(kù),達(dá)到不編寫sql語(yǔ)句就可以對(duì)數(shù)據(jù)庫(kù)進(jìn)行增刪改查的一種技術(shù),但是orm底層還是通過原生sql去實(shí)現(xiàn)的。
上圖所示,而模型的對(duì)象就相當(dāng)于表中數(shù)據(jù)。
2.django配置數(shù)據(jù)庫(kù)
在配置數(shù)據(jù)庫(kù)前需要安裝mysql驅(qū)動(dòng),此環(huán)境用的是mariadb數(shù)據(jù)庫(kù),安裝驅(qū)動(dòng):
pip install mysqlclient
安裝完成后可以通過如下兩種方式添加配置信息:
第一種方式:
直接在settings.py中配置:
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': '庫(kù)名', 'USER': '用戶名', 'PASSWORD': '用戶密碼', 'HOST': '域名', 'PORT': '端口號(hào)' } }
第二種方式:
添加配置文件:
根目錄下新建配置文件目錄,并創(chuàng)建配置文件填寫數(shù)據(jù)庫(kù)信息:
# my.cnf [client] database = 庫(kù)名 user = 用戶名 password = 用戶密碼 host = 域名 port = 端口
settings.py 中:
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'OPTIONS': { 'read_default_file': str(BASE_DIR / [配置文件路徑]) } } }
三、模型設(shè)計(jì)
django中的模型準(zhǔn)確且唯一的描述了數(shù)據(jù),每個(gè)模型都是一個(gè)python類,繼承django.db.models.Model類。模型類中的每個(gè)熟悉為數(shù)據(jù)庫(kù)中的字段,diango提供了一個(gè)自動(dòng)生成訪問數(shù)據(jù)庫(kù)的API。
1.創(chuàng)建模型
每個(gè)應(yīng)用的模型都會(huì)被編寫到models.py文件下,如圖,創(chuàng)建項(xiàng)目時(shí)會(huì)自動(dòng)引入models模塊。
創(chuàng)建一個(gè)學(xué)生表為例:
from django.db import models # Create your models here. class Stutent(models.Model): """ 學(xué)生表 """ name = models.CharField('學(xué)生姓名', max_length=200, unique=True, help_text='學(xué)生姓名') 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)建時(shí)間', auto_now_add=True, help_text='創(chuàng)建時(shí)間') class Meta: """ 元數(shù)據(jù), """ db_table = 'student' # 指定當(dāng)前模型創(chuàng)建的表明,不寫默認(rèn)當(dāng)前的模型名Student verbose_name = '學(xué)生信息表' # 注釋 verbose_name_plural = verbose_name # 指定為復(fù)數(shù) ordering = ['-create_time'] # 使用創(chuàng)建時(shí)間倒序排序,不加-為正序
CharField 字符類型代表數(shù)據(jù)庫(kù)中的VARCHAR DateTimeField 日期字段類型 IntegerField 整數(shù)字段類型 FloatField 數(shù)值字段類型 DecimalField 高精度字段類型 max_length 數(shù)據(jù)的長(zhǎng)度限制,當(dāng)使用CharField時(shí),此字段必傳,否則報(bào)錯(cuò) unique 為True 代表字段唯一 null 為True 代表可以為空 blank 為True 不校驗(yàn)此字段 SmallIntegerField 小整數(shù) auto_now_add 結(jié)合DateTimeField 使用,默認(rèn)為當(dāng)前時(shí)間
2.表關(guān)系
Django中的表關(guān)系可以通過下面方式表達(dá)
一對(duì)多關(guān)系:models.ForeignKey() 在多的一方創(chuàng)建 多對(duì)多關(guān)系:models.ManyToManyField() 隨便表創(chuàng)建 一對(duì)一關(guān)系:models.OneToOneField() 隨便表創(chuàng)建
繼續(xù)創(chuàng)建學(xué)生班級(jí)模型:
class Class(models.Model): name = models.CharField('班級(jí)名稱', max_length=200) class_num = models.IntegerField('班級(jí)', unique=True, help_text='班級(jí)number') student = models.ForeignKey(Stutent, on_delete=models.CASCADE) # 設(shè)置外鍵,on_delete級(jí)聯(lián)刪除
四、模型應(yīng)用
數(shù)據(jù)庫(kù)遷移前需要將應(yīng)用在settings文件的INSTALLED_APPS中去注冊(cè)
第一步:
生成數(shù)據(jù)遷移記錄 python manage.py makemigrations projects
運(yùn)行命令后會(huì)在migrations目錄下生成遷移記錄文件,id會(huì)自動(dòng)創(chuàng)建,如下:
django底層是用sql實(shí)現(xiàn)的,查看執(zhí)行遷移生成的sql命令如下:
python manage.py sqlmigrate projects 0001
第二步:
執(zhí)行遷移
python manage.py migrate
執(zhí)行命令后數(shù)據(jù)庫(kù)生成表信息
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
python如何生成網(wǎng)頁(yè)驗(yàn)證碼
這篇文章主要為大家詳細(xì)介紹了python如何生成網(wǎng)頁(yè)驗(yàn)證碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-07-07python之語(yǔ)句mode = 'test' if y&nb
這篇文章主要介紹了python之語(yǔ)句mode = 'test' if y is None else 'train'問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02使用Flask-Cache緩存實(shí)現(xiàn)給Flask提速的方法詳解
這篇文章主要介紹了使用Flask-Cache緩存實(shí)現(xiàn)給Flask提速的方法,結(jié)合實(shí)例形式詳細(xì)分析了Flask-Cache的安裝、配置及緩存使用相關(guān)操作技巧,需要的朋友可以參考下2019-06-06python for循環(huán)內(nèi)輸出和外輸出方式
這篇文章主要介紹了python for循環(huán)內(nèi)輸出和外輸出方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-03-03python如何調(diào)用php文件中的函數(shù)詳解
這篇文章主要給大家介紹了關(guān)于python如何調(diào)用php文件中函數(shù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12python框架flask入門之路由及簡(jiǎn)單實(shí)現(xiàn)方法
這篇文章主要介紹了python框架flask入門路由及路由簡(jiǎn)單實(shí)現(xiàn)方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06