ORM簡介 MVC框架中包括一個重要的部分,就是ORM,它實現了數據模型與資料庫的解耦,即數據模型的設計不需要依賴於特定的資料庫,通過簡單的配置就可以輕鬆更換資料庫 ORM是“對象-關係-映射”的簡稱,主要任務是: 根據對象的類型生成表結構 將對象、列表的操作,轉換為sql語句 將sql查詢到的結果 ...
ORM簡介
MVC框架中包括一個重要的部分,就是ORM,它實現了數據模型與資料庫的解耦,即數據模型的設計不需要依賴於特定的資料庫,通過簡單的配置就可以輕鬆更換資料庫
ORM是“對象-關係-映射”的簡稱,主要任務是:
根據對象的類型生成表結構
將對象、列表的操作,轉換為sql語句
將sql查詢到的結果轉換為對象、列表
這極大的減輕了開發人員的工作量,不需要面對因資料庫變更而導致的無效勞動
Django中的模型包含存儲數據的欄位和約束,對應著資料庫中唯一的表
定義模型
- 在模型中定義屬性,會生成表中的欄位
- django根據屬性的類型確定以下信息:
- 當前選擇的資料庫支持欄位的類型
- 渲染管理表單時使用的預設html控制項
- 在管理站點最低限度的驗證
- django會為表增加自動增長的主鍵列,每個模型只能有一個主鍵列,如果使用選項設置某屬性為主鍵列後,則django不會再生成預設的主鍵列
- 屬性命名限制
- 不能是python的保留關鍵字
- 由於django的查詢方式,不允許使用連續的下劃線
定義屬性
- 定義屬性時,需要欄位類型
- 欄位類型被定義在django.db.models.fields目錄下,為了方便使用,被導入到django.db.models中
- 使用方式
- 導入from django.db import models
- 通過models.Field創建欄位類型的對象,賦值給屬性
- 對於重要數據都做邏輯刪除,不做物理刪除,實現方法是定義isDelete屬性,類型為BooleanField,預設值為False
欄位類型
- AutoField:一個根據實際ID自動增長的IntegerField,通常不指定
- 如果不指定,一個主鍵欄位將自動添加到模型中
- BooleanField:true/false 欄位,此欄位的預設表單控制是CheckboxInput
- NullBooleanField:支持null、true、false三種值
- CharField(max_length=字元長度):字元串,預設的表單樣式是 TextInput
- TextField:大文本欄位,一般超過4000使用,預設的表單控制項是Textarea
- IntegerField:整數
- DecimalField(max_digits=None, decimal_places=None):使用python的Decimal實例表示的十進位浮點數
- DecimalField.max_digits:位數總數
- DecimalField.decimal_places:小數點後的數字位數
- FloatField:用Python的float實例來表示的浮點數
- DateField[auto_now=False, auto_now_add=False]):使用Python的datetime.date實例表示的日期
- 參數DateField.auto_now:每次保存對象時,自動設置該欄位為當前時間,用於"最後一次修改"的時間戳,它總是使用當前日期,預設為false
- 參數DateField.auto_now_add:當對象第一次被創建時自動設置當前時間,用於創建的時間戳,它總是使用當前日期,預設為false
- 該欄位預設對應的表單控制項是一個TextInput. 在管理員站點添加了一個JavaScript寫的日曆控制項,和一個“Today"的快捷按鈕,包含了一個額外的invalid_date錯誤消息鍵
- auto_now_add, auto_now, and default 這些設置是相互排斥的,他們之間的任何組合將會發生錯誤的結果
- TimeField:使用Python的datetime.time實例表示的時間,參數同DateField
- DateTimeField:使用Python的datetime.datetime實例表示的日期和時間,參數同DateField
- FileField:一個上傳文件的欄位
- ImageField:繼承了FileField的所有屬性和方法,但對上傳的對象進行校驗,確保它是個有效的image
欄位選項
- 通過欄位選項,可以實現對欄位的約束
- 在欄位對象時通過關鍵字參數指定
- null:如果為True,Django 將空值以NULL 存儲到資料庫中,預設值是 False
- blank:如果為True,則該欄位允許為空白,預設值是 False
- 對比:null是資料庫範疇的概念,blank是表單驗證證範疇的
- db_column:欄位的名稱,如果未指定,則使用屬性的名稱
- db_index:若值為 True, 則在表中會為此欄位創建索引
- default:預設值
- primary_key:若為 True, 則該欄位會成為模型的主鍵欄位
- unique:如果為 True, 這個欄位在表中必須有唯一值
關係
- 關係的類型包括
- ForeignKey:一對多,將欄位定義在多的端中
- ManyToManyField:多對多,將欄位定義在兩端中
- OneToOneField:一對一,將欄位定義在任意一端中
- 可以維護遞歸的關聯關係,使用'self'指定
- 用一訪問多:對象.模型類小寫_set
開發流程
- 在models.py中定義模型類,要求繼承自models.Model
- 把應用加入settings.py文件的installed_app項
- 生成遷移文件
- 執行遷移生成表
- 使用模型類進行crud操作
示例
進入虛擬環境創建項目:django-admin startproject firstProject
創建應用程式:python manage.py startapp usertest 創建一個應用程式,一個項目中可以包含多個應用程式
然後執行pycharm打開pycharm(前提是已經添加了環境變數),打開剛剛創建的項目
設置keymap和編譯環境,keymap可以選擇自己熟悉使用的IDE風格環境,編譯環境選擇之前創建好的虛擬環境,當然也可以自己新建一個虛擬環境
創建資料庫
- 在虛擬環境中安裝mysql包
pip install mysql-python
- 在mysql中創建資料庫
create databases usertest charset=utf8
資料庫配置
- 在settings.py文件中,通過DATABASES項進行資料庫設置
- django支持的資料庫包括:sqlite、mysql等主流資料庫
- Django預設使用SQLite資料庫
DATABASES = { 'default': { 'ENGINE': 'django.db.backends.mysql', 'NAME': 'test2', 'USER': '用戶名', 'PASSWORD': '密碼', 'HOST': '資料庫伺服器ip,本地可以使用localhost', 'PORT': '埠,預設為3306', } }
編寫模型類
- 有一個數據表,就有一個模型類與之對應
- 打開models.py文件,定義模型類
- 引入包from django.db import models
- 模型類繼承自models.Model類
- 說明:不需要定義主鍵列,在生成時會自動添加,並且值為自動增長
# -*- coding: utf-8 -*- from __future__ import unicode_literals from django.db import models # Create your models here. #角色類 class RoleInfo(models.Model): rolename = models.CharField(max_length=20) #用戶類 class UserInfo(models.Model): username = models.CharField(max_length=20) userage = models.IntegerField() usercreatdate = models.DateField() userrole = models.ForeignKey('RoleInfo')
激活模型:編輯settings.py文件,將usertest應用加入到installed_apps中
INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'usertest', ]
- 生成遷移文件:根據模型類生成sql語句
python manage.py makemigrations
- 執行遷移:執行sql語句生成數據表
python manage.py migrate
測試資料庫
進入python shell,進行簡單的模型API練習
python manage.py shell
再去資料庫中查詢,可以看到有數據了