使用Python的Django模型的話,一般都會用它自帶的ORM(Object-relational mapping)模型。這個ORM模型的設(shè)計比較簡單,學(xué)起來不會特別花時間。不過,Django的ORM模型有自己的一套語法,有時候會覺得別扭。這里聊一下我自己的體會。

 

模型設(shè)計

這一部分算處理得比較好的部分。Django的數(shù)據(jù)模型的建立過程很簡單,就是繼承django.db.models中的Model類,然后給它增加屬性。每一個屬性可以對應(yīng)關(guān)系數(shù)據(jù)庫中的一個字段。比如在一個叫myapp的Django App下,創(chuàng)建models.py文件:

from django.db import modelsclass Person(models.Model):
    name = models.CharField(max_length=10)

通過manage.py的makemigrations和migrate命令,就可以執(zhí)行數(shù)據(jù)庫的遷移。上面的name屬性,就對應(yīng)了生成的myapp_person表中名為"name"的一列。這里的max_length=10對應(yīng)了限制條件:

VARCHAR(10)

(在MySQL V4中,代表了10個字節(jié);在MySQL V5中,代表了10個字符。)

 

除了上面的字符類型,其他常見的字段類型,在Django都有對應(yīng)的*Field來表達(dá),比如TextField、DateField、DateTimeField、IntegerField、DecimalField。此外,還有一些常見的限制條件,除了上面的max_length,還有default、unique、null、primary_key等等。數(shù)字類型的限制條件有max、min、max_digits、decimal_places。這些限制條