一、 環境準備:
1.docker環境
docker環境如下:
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:設置環境變量數據庫相關信息
- d:后臺運行容器mariadb并返回容器id
- mariadb:latest:啟動最新的鏡像版本
等待命令運行結束后可以查看啟動的容器:
navicat連接測試:
創建好的數據庫:
二、ORM
1.ORM簡介
orm(object relational mapping )對象關系映射,用面向對象的方式,描述數據庫,操作數據庫,達到不編寫sql語句就可以對數據庫進行增刪改查的一種技術,但是orm底層還是通過原生sql去實現的。
上圖所示,而模型的對象就相當于表中數據。
2.django配置數據庫
在配置數據庫前需要安裝mysql驅動,此環境用的是mariadb數據庫,安裝驅動:
pip install mysqlclient
安裝完成后可以通過如下兩種方式添加配置信息:
第一種方式:
直接在settings.py中配置:
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': '庫名', 'USER': '用戶名', 'PASSWORD': '用戶密碼', 'HOST': '域名', 'PORT': '端口號' } }
第二種方式:
添加配置文件:
根目錄下新建配置文件目錄,并創建配置文件填寫數據庫信息:
# 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.創建模型
每個應用的模型都會被編寫到models.py文件下,如圖,創建項目時會自動引入models模塊。
創建一個學生表為例:
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('創建時間', auto_now_add=True, help_text='創建時間') class Meta: """ 元數據, """ db_table = 'student' # 指定當前模型創建的表明,不寫默認當前的模型名Student verbose_name = '學生信息表' # 注釋 verbose_name_plural = verbose_name # 指定為復數 ordering = ['-create_time'] # 使用創建時間倒序排序,不加-為正序
CharField 字符類型代表數據庫中的VARCHAR DateTimeField 日期字段類型 IntegerField 整數字段類型 FloatField 數值字段類型 DecimalField 高精度字段類型 max_length 數據的長度限制,當使用CharField時,此字段必傳,否則報錯 unique 為True 代表字段唯一 null 為True 代表可以為空 blank 為True 不校驗此字段 SmallIntegerField 小整數 auto_now_add 結合DateTimeField 使用,默認為當前時間
2.表關系
Django中的表關系可以通過下面方式表達
一對多關系:models.ForeignKey() 在多的一方創建 多對多關系:models.ManyToManyField() 隨便表創建 一對一關系:models.OneToOneField() 隨便表創建
繼續創建學生班級模型:
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會自動創建,如下:
django底層是用sql實現的,查看執行遷移生成的sql命令如下:
python manage.py sqlmigrate projects 0001
第二步:
執行遷移
python manage.py migrate
執行命令后數據庫生成表信息
總結
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關注服務器之家的更多內容!
原文鏈接:https://blog.csdn.net/weixin_42262081/article/details/121225712V