Django-ORM簡介


ORM簡介

  • MVC框架中包括一個重要的部分,就是ORM,它實現了數據模型與數據庫的解耦,即數據模型的設計不需要依賴於特定的數據庫,通過簡單的配置就可以輕松更換數據庫
  • ORM是“對象-關系-映射”的簡稱,主要任務是:
    • 根據對象的類型生成表結構
    • 將對象、列表的操作,轉換為sql語句
    • 將sql查詢到的結果轉換為對象、列表
  • 這極大的減輕了開發人員的工作量,不需要面對因數據庫變更而導致的無效勞動
  • Django中的模型包含存儲數據的字段和約束,對應着數據庫中唯一的表

使用MySql數據庫

  • 在虛擬環境中安裝mysql包
pip install mysql-python
  • 在mysql中創建數據庫
create databases test2 charset=utf8
  • 打開settings.py文件,修改DATABASES項
DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql',
        'NAME': 'test2',
        'USER': '用戶名',
        'PASSWORD': '密碼',
        'HOST': '數據庫服務器ip,本地可以使用localhost',
        'PORT': '端口,默認為3306',
    }
}

 

開發流程

  1. 在models.py中定義模型類,要求繼承自models.Model
  2. 把應用加入settings.py文件的installed_app項
  3. 生成遷移文件
  4. 執行遷移生成表
  5. 使用模型類進行crud操作

定義模型

  • 在模型中定義屬性,會生成表中的字段
  • django根據屬性的類型確定以下信息:
    • 當前選擇的數據庫支持字段的類型
    • 渲染管理表單時使用的默認html控件
    • 在管理站點最低限度的驗證
  • django會為表增加自動增長的主鍵列,每個模型只能有一個主鍵列,如果使用選項設置某屬性為主鍵列后,則django不會再生成默認的主鍵列
  • 屬性命名限制
    • 不能是python的保留關鍵字
    • 由於django的查詢方式,不允許使用連續的下划線

定義屬性

  • 定義屬性時,需要字段類型
  • 字段類型被定義在django.db.models.fields目錄下,為了方便使用,被導入到django.db.models中
  • 使用方式
    1. 導入from django.db import models
    2. 通過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

ORM操作

 models.UserInfo.object.create(name=new_name)

models.UserInfo.object.get(id=xxx,None)
models.delete()

obj = models.UserInfo.object.get(id=xx,None)
obj = new_xxx
obj.save() #相當於修改后提交數據

querylist=models.Entry.objects.all()
print([e.title for e in querylist])
print([e.title for e in querylist])

entry = models.Entry.objects.get(id=?)

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM