人妖在线一区,国产日韩欧美一区二区综合在线,国产啪精品视频网站免费,欧美内射深插日本少妇

新聞動(dòng)態(tài)

Python Django ORM與模型詳解

發(fā)布日期:2021-12-12 16:29 | 文章來源:站長之家

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

1.docker環(huán)境

docker環(huán)境如下:

2.安裝mariadb數(shù)據(jù)庫

運(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=[庫名] mariadb:latest

參數(shù)詳解:

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

等待命令運(yùn)行結(jié)束后可以查看啟動(dòng)的容器:


navicat連接測試:


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

二、ORM

1.ORM簡介

orm(object relational mapping )對象關(guān)系映射,用面向?qū)ο蟮姆绞?,描述?shù)據(jù)庫,操作數(shù)據(jù)庫,達(dá)到不編寫sql語句就可以對數(shù)據(jù)庫進(jìn)行增刪改查的一種技術(shù),但是orm底層還是通過原生sql去實(shí)現(xiàn)的。


上圖所示,而模型的對象就相當(dāng)于表中數(shù)據(jù)。

2.django配置數(shù)據(jù)庫

在配置數(shù)據(jù)庫前需要安裝mysql驅(qū)動(dòng),此環(huán)境用的是mariadb數(shù)據(jù)庫,安裝驅(qū)動(dòng):

pip install mysqlclient

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

第一種方式:

直接在settings.py中配置:

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

第二種方式:

添加配置文件:

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

# my.cnf
[client]
database = 庫名
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ù)庫中的字段,diango提供了一個(gè)自動(dòng)生成訪問數(shù)據(jù)庫的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ù)庫中的VARCHAR
DateTimeField  日期字段類型
IntegerField  整數(shù)字段類型
FloatField  數(shù)值字段類型
DecimalField  高精度字段類型
max_length  數(shù)據(jù)的長度限制,當(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á)

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

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

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)  # 設(shè)置外鍵,on_delete級聯(lián)刪除

四、模型應(yīng)用

數(shù)據(jù)庫遷移前需要將應(yīng)用在settings文件的INSTALLED_APPS中去注冊


第一步:

生成數(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ù)庫生成表信息

總結(jié)

本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注本站的更多內(nèi)容!

版權(quán)聲明:本站文章來源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請保持原文完整并注明來源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非www.sddonglingsh.com所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來,僅供學(xué)習(xí)參考,不代表本站立場,如有內(nèi)容涉嫌侵權(quán),請聯(lián)系alex-e#qq.com處理。

相關(guān)文章

實(shí)時(shí)開通

自選配置、實(shí)時(shí)開通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問服務(wù)

1對1客戶咨詢顧問

在線
客服

在線客服:7*24小時(shí)在線

客服
熱線

400-630-3752
7*24小時(shí)客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部