一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - Python Django ORM與模型詳解

Python Django ORM與模型詳解

2022-02-27 14:03久醉繞心弦, Python

這篇文章主要介紹了django的ORM與模型的實現(xiàn)原理,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

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

1.docker環(huán)境

docker環(huán)境如下:

Python Django ORM與模型詳解

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

運行如下命令

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

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

Python Django ORM與模型詳解

navicat連接測試:

Python Django ORM與模型詳解

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

Python Django ORM與模型詳解

 

二、ORM

1.ORM簡介

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

Python Django ORM與模型詳解

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

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

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

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 / [配置文件路徑])
      }
  }
}

 

三、模型設計

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

1.創(chuàng)建模型

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

Python Django ORM與模型詳解

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

CharField   字符類型代表數(shù)據(jù)庫中的VARCHAR
DateTimeField  日期字段類型
IntegerField  整數(shù)字段類型
FloatField  數(shù)值字段類型
DecimalField  高精度字段類型
max_length  數(shù)據(jù)的長度限制,當使用CharField時,此字段必傳,否則報錯
unique 為True  代表字段唯一
null 為True  代表可以為空
blank 為True  不校驗此字段
SmallIntegerField 小整數(shù)
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級聯(lián)刪除

 

四、模型應用

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

Python Django ORM與模型詳解

第一步:

生成數(shù)據(jù)遷移記錄
python manage.py makemigrations projects

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

Python Django ORM與模型詳解

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

python manage.py sqlmigrate projects 0001

Python Django ORM與模型詳解

第二步:

執(zhí)行遷移

python manage.py migrate 

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

Python Django ORM與模型詳解

 

總結

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

原文鏈接:https://blog.csdn.net/weixin_42262081/article/details/121225712V

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 高清欧美不卡一区二区三区 | 日本三级大学生17 | 俄罗斯性高清完整版 | japanese秘书丝袜 | 国产一级黄色录像 | 出轨同学会免费观看 | 99久久一香蕉国产线看观看 | 九9热这里只有真品 | 日本漫画工囗全彩内番e绅 日本伦理动漫在线观看 | 国产播放器一区 | a v在线男人的天堂观看免费 | 天天色天天舔 | 日本精品欧洲www | 沟厕okn系列在线播放 | 精品亚洲视频在线观看 | 国产亚洲精品一区在线播 | 亚洲国产99在线精品一区69堂 | 国产第2页| 国产精品亚洲一区二区久久 | 日本无翼乌漫画 | 国产精品久久久久久搜索 | 色综合天天综合网看在线影院 | 国产拍拍视频一二三四区 | 午夜精品久久久久久久99蜜桃 | 羞羞影院午夜男女爽爽影院网站 | 亚洲 在线 日韩 欧美 | 午夜宅男网 | 免费高清视频免费观看 | 午夜家庭影院 | 国产精品激情综合久久 | 苍井空色欲迷墙 | 亚洲国产美女精品久久久久 | 高清在线看 | 日本在线观看www免费 | 男人晚上看的 | 微福利92合集| 亚洲精品青青草原avav久久qv | 免费特黄一区二区三区视频一 | 免费日批软件 | 99久女女精品视频在线观看 | 亚洲 欧美 中文字幕 在线 |