使用Python的Django模型的話,一般都會(huì)用它自帶的ORM(Object-relational mapping)模型。這個(gè)ORM模型的設(shè)計(jì)比較簡(jiǎn)單,學(xué)起來(lái)不會(huì)特別花時(shí)間。不過(guò),Django的ORM模型有自己的一套語(yǔ)法,有時(shí)候會(huì)覺(jué)得別扭。這里聊一下我自己的體會(huì)。

 

模型設(shè)計(jì)

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

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

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

VARCHAR(10)

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

 

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